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Preface 


The RSTS/E Maintenance Notebook is a maintenance notebook for 
documentation corrections, published software problems and solutions, 
and programming notes. Subordinate software information is also 
included. The RSTS/E Software Dispatch Review and the RSTS/E Software 
Dispatch are designed so that their articles may be merged into the 
Maintenance Notebook. 


The RSTS/E Software Dispatch Review contains articles published for 
optional layered software supported on RSTS/E V9.0. In general, this 


is a composite of all optional layered software articles previously 
published for RSTS/E, which still apply to the product when run on 
RSTS/E V9.0. 


The RSTS/E Software Dispatch is published monthly and distributed to 
customers who have purchased a software service contract from DIGITAL. 
Contact your local DIGITAL office for more information on how to 
obtain a software service contract if you do not already have one. 


The RSTS/E Software Dispatch contains articles for RSTS/E and its 
layered software. Each month, you should take apart the RSTS/E 
Software Dispatch and merge the new articles by sequence number in 
your maintenance notebook. 


All articles published are summarized in the Cumulative Index. There 
is also an index of the version and edit levels for all the Commonly 
Used System Programs (CUSPs). These indexes are updated as necessary 


in the RSTS/E Software Dispatch. 
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1.0 Notebook Maintenance 


Each month you should take apart the RSTS/E Software Dispatch and 
merge the new articles by sequence number in your notebook. If an 
article is a replacement, discard the superseded article. Each 
article addresses a single topic and its title gives the symptom or a 
one-line problem description. This information appears at the top of 
each page. For example: 


RSTS/E Software Dispatch, Month year 


RSTS/E V9.0 Seq 4.1.4 F 
BASIC-PLUS 
BASIC-PLUS Patches 1 of 2 


DEFAULT TO NOEXTEND MODE - BASIC-PLUS FEATURE PATCH 


The system components and subcomponents are listed in Section 2.0. 
That list will be updated periodically as products become available or 
obsolete. Articles for each subcomponent are assigned a sequencing 
number which uniquely identifies the article within that 
component.subcomponent category. As each new article is published for 
a subcomponent, it is assigned the next higher sequence number. The 
entire number is defined as the COMPONENT.SUBCOMPONENT.ISSUE number, 
an example being the "4.1.4" shown in the upper right corner of the 
sample heading. Replacement articles are identified as such. 


In general, articles with an issue number of zero 
(component.subcomponent.0) are provided to list problems corrected by 
a replacement module for the affected component. These articles will 
be superseded each time a new replacement module is issued for the 
component. 
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Each 


M 


x) 


article's sequence number will be followed by a letter, 
identifying the type of article, as explained below: 


Mandatory 


These articles describe problems corrected by a replacement 
module. In some cases, these articles will also include a 
patching procedure you can follow to correct a problem. You 
are required to install replacement modules or apply patches 
described in a "M" article unless told otherwise. 


FEATURE 


These articles include patches that extend or configure 
non-standard capabilities into the product. These functions 
will be treated as a supported part of the product for the 
duration of the current release. 


RESTRICTION 


These articles discuss areas that will not be patched in the 
current release because they require major modifications or 
because they are not consistent with the design of the 
product. Restrictions, except those described as permanent, 
are reviewed and modified when possible as part of the 
normal release cycle. 


NOTE 


These articles provide explanatory information that 
supplements the documentation set and provides more detailed 
information about a program or package. They also provide 
procedural information to make it easier to use a program or 
package. 
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2.0 RSTS/E Component.Subcomponent Assignments 


The component.subcomponent numbers outlined below appear on 
to be filed following Section 6.1 of this notebook. 


RSTS/E MONITOR 


0 RSTS/E V9.0 General Notes 
Od System Notes 
052 System Management Guidelines 


Initialization 
1 INIT.SYS Program Patches 
2 INIT.SYS Program Notes 


NO 
° 


System Installation and Update 
Installation/Update Notes 
Installation/Update .COM files 
BPLGEN.SAV 
BUFCHK. TSK 
SYSGEN.SAV 
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Monitor 

Monitor Patches 
Monitor Notes 

Terminal Service Patches 
Terminal Service Notes 
File Processor Patches 
File Processor Notes 
Device Driver Patches 
Device Driver Notes 
FMS Monitor Patches 

0 FMS Monitor Notes 
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BASIC-PLUS 
BASIC-PLUS Patches 
BASIC-PLUS Notes 
Programming Hints 
Math Packages 
Matrix Functions 
PRINT-USING 
Record I/O 
Virtual Core 
String Arithmetic 
Non-Standard BASIC-PLUS Features 


mO OAH ONE WN FF 


(=) 


PP PPP PP PP PO 
e 


Page 2-1 


articles 


RSTS/E V9.0 Maintenance Notebook, June 1985 
Component.Subcomponent Assignments 


5.0 RSTS/E 2780 Device Driver 
Sd RSTS/E 2780 Device Driver Patches 
O42 RSTS/E 2780 Device Driver Notes 
6.0 System Files 
6.1 System Files Notes 
6.2 BACKUP.TSK 
6.3 CSPLIB.LIB 
6.4 ERR.ERR 
6.5 INIT.SYS 
6.6 LOGIN.COM 
6.7 RECOVR.COM 
6.8 START .COM 
6.9 SYSGEN.SIL 
6.10 SYSINI.COM 
7.0 DECnet/E Monitor Package V2.1 
Tee Package Notes 
eZ DECNET .OBJ 
dad NSPSUB. OBJ 
7.4 NSP .OBJ 
149 NET. OBJ 
7.6 TRN.OBJ 
Ted SES . OBJ 
7.8 XDDVR. OBJ 
1429 XDDINT.OBJ 


RSTS/E UTILITIES 


Help Package (HELPS) 
Package Notes 
HELP.TSK 


oM © 
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TECO Package (TECOS) 
TECO Notes 
TECO.RTS 
TECO. TEC 
VTEDIT.TEC 
TECO.INI 
TYPE. TEC 
SQU.TEC 
LOCAL, TEC 
TECKBM. TEC 
SEARCH, TEC 
TECO.DOC 
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11.10 
oie ee 8 
Lib. 13 
11.14 


12.0 
tel 
12.2 
12.3 
12.4 
L2¢9 
12.6 
AP 
12.8 
269 
12.10 
12.11 


System Library ($) 
Library Notes 


ACTMGR. TSK 
ATPK.TSK 

DIRECT.TSK 
DSKINT.TSK 
FILCOM. TSK 
LOGIN.TSK 

LOGOUT. TSK 
MAKSIL.TSK 
ONLPAT. SAV 
REORDR. TSK 
SHUTUP. TSK 
SWITCH. TSK 
SYSTAT. TSK 
TERMGR. TSK 
UTLMGR. TSK 


Auxiliary Library (AUXLIBS) 
Package Notes 


BPCREF. TSK 
BPCRF1.TSK 
COPY .TSK 
DISPLY.TSK 
DSKCVT. TSK 
FIT.TSK 
FLINT.TSK 
GRIPE.TSK 
ODT .TSK 
PMDUMP. TSK 
RUNOFF. TSK 
TALK. TSK 


Error Control Package (ERRORS) 
Package Notes 


ANALY1.TSK 
ANALY2.TSK 
ANALY3.TSK 
ANALYS.TSK 
ERRCPY.TSK 
ERRDAT. FIL 
ERRDET. TSK 
ERRDIS.TSK 
ERRINT.TSK 
MSCPER.FIL 
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13.0 
cle Wee 
i oe2 
13.3 
13.4 


14.12 
14.13 
14.14 
14.15 
14.16 
14.17 


15.0 
Ec yr 
poe 
Lb. 
15.4 
Le 


RESTOR Package (RESTORS) 
Package Notes 
BACCOM. TSK 
BACCON .TSK 
BACDIR.TSK 
BACDSK. TSK 
BACENT. TSK 
BACFRM. TSK 
BACLAB.TSK 
BACLOD. TSK 
BACLST. TSK 
BACMNT. TSK 
BACKUP. PRM 
RESTOR. TSK 


Operator Services and Spooling Package (OPSERS) 
Package Notes 
BATCH. DCD 
BATCH. TSK 
BATDCD. TSK 
BATDEC.TSK 
BATIDL.TSK 
BATRUN.TSK 
CHARS .QUE 
OPSER. TSK 
OPSRUN.TSK 
PLEASE. TSK 
QUE.TSK 
QUEMAN. TSK 
QUMRUN. TSK 
SPLIDL.TSK 
SPLRUN.TSK 
SPOOL. TSK 


Print/Batch Services Package (PBSS$) 
Package Notes 

FORMS.SYS 

PBS .TSK 

PBSMGR. TSK 

QUE.SYS 


Page 2-4 


RSTS/E V9.0 Maintenance Notebook, June 1985 
Component.Subcomponent Assignments 


16.0 
16.1 
16.2 
16.3 
16.4 
16.5 
16.6 
L6u7 
16.8 
16.9 
16.10 
V6u21 
L6e12 
16.13 
16.14 
16.15 
16.16 
16.17 
16.18 
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18.10 
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Unsupported Package (UNSUPPS) 
Package Notes 
BPDA.TSK 
B2CREF.TSK 
CONNEC. TSK 
DIALER.TSK 
DSKDMP. TSK 
DUMP .TSK 
EMTCPY.TSK 
FLOAT. TSK 
LOSTAT. TSK 
MEMORY. TSK 
MONEY. TSK 
QSTATS.TSK 
RNO.TSK 
RSTSFL. OBJ 
SRCCOM. SAV 
STATUS.TSK 
VT55.TSK 


Layered Product Update Package (UPDATES) 
Package Notes 

AUTOED.TSK 

BUILD.TSK 

CPATCH. TSK 

CSPCOM. TSK 

CSPCOM.OLB 

UTILTY.TSK 


Device Test Package (TESTS) 
Package Notes 
CPEXER.TSK 
CPUTST. TSK 
DDEXER. TSK 
DSKSEK.TSK 
DTEXER.TSK 
DXEXER.TSK 
DSKEXR. TSK 
KBEXER. TSK 
LPEXER.TSK 
MTEXER. TSK 
PPEXER.TSK 
PREXER.TSK 
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19.0 
19.1 
19.2 
19.3 


RSTS/E DOCUMENTATION 


Documentation 

RSTS/E Documentation Directory 

RSTS/E V9.0 Release Notes 

RSTS/E V9.0 Maintenance Notebook 

RSTS/E System Installation and Update Guide 
RSTS/E System Manager's Guide 

RSTS/E System User's Guide 

RSTS/E Guide to Writing Command Procedures 
RSTS/E Utilities Reference Manual 
Introduction to the EDT Editor 

PDP-11 SORT/MERGE User's Guide 

RSTS/E RUNOFF User's Guide 

EDT Editor Manual 

RSTS/E Task Builder Reference Manual 

RSTS/E Task Builder Reference Manual Update 
RSTS/E Programmer's Utilities Manual 

RSTS/E Programmer's Utilities Manual Updatel 
RSTS/E Programmer's Utilities Manual Update2 
RSTS/E RT11 Utilities Manual 

PDP-11 TECO User's Guide 

BASIC-PLUS Language Manual 

RSTS/E Programming Manual 

RSTS/E System Directives Manual 

IAS/RSX-11 ODT Reference Manual 

PDP-11 MACRO-11 Language Reference Manual 
PDP-11 MACRO-11 Language Reference Manual Update 
RSTS/E RMS-11 MACRO Programmer's Guide 
RSTS/E RMS-11: An Introduction 

RSTS/E RMS-11 User's Guide 

RSTS/E RMS-11 Utilities Manual 

RSTS/E Quick Reference Guide 

Introduction to BASIC 

EDT Quick Reference Guide 
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RUN-TIME SYSTEMS SUPPORT 


20.0 DCL Run-time System and Utilities 
20.1 Package Notes . 
20.2 DCL.RTS 
20.3 DCLUTL.TSK 
20.4 PRELIN.TSK 


21.0 RSX Run-time System and Utilities 
Ziel: Package Notes 
21:2 CRF. TSK 
2hes LBR.TSK 
21.4 MAC.TSK 
21S PAT .TSK 
21.6 RSX.RTS 
2167 RSXMAC.SML 
21.8 STK.TSK 
21.9 SYSLIB.OLB 
21.10 MTKB.TSK 


22.0 RT-11 Run-time System and Utilities 
2261 Package Notes 
22.2 CREF .SAV 
2243 HOOK .SAV 
22.4 LIBR.SAV 
22:5 LINK.SAV 
22.6 MACRO.SAV 
22.7 ONLPAT.SAV 
22.8 PAT.SAV 
2269 PIP.SAV 
22.10 RT11.RTS 
22.11 SAVRES.SAV 
22.12 SILUS.SAV 
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23.0 
2S 


24.0 

25.0 
29eL 
25.2 
25.3 

26.0 


27.0 
2hed 


28.0 
29.0 
30.0 


OPTIONAL SOFTWARE 

EDT V3.0 

Package Notes 

(Reserved) 
RSTS/E 2780 Package V3.0 

Package Notes 

RJ2780 

RSTS/E 2780 User's Guide (DEC-11-ORJEA-B-D) 


(Reserved) 


FMS-11 V1.5 
Package Notes 


(Reserved) 
(Reserved) 


(Reserved) 
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31.0 DECnet/E Utilities V2.1 (DECNETS) 
31.1 Package Notes 
312 DTRECV. TSK 
Sde3 DTSEND. TSK 
31.4 EVTLOG. TSK 
345 FAL.TSK 
31.6 LSN.TSK 
3167 MIRROR. TSK 
31.8 NCP.TSK 
31.9 NCUCVT. TSK 
31.10 NET.TSK 
31.11 NFT.TSK 
31.12 NETCPY.TSK 
31.13 NETCVT.TSK 
31.14 NETFNC.BAS 
31.15 NETMLB (.MLB and .SML) 
31.16 NETOFF.TSK 
31.17 NETPAT.SAV 
31.18 NETSLP.TSK 
31.19 NPKDVR.TSK 
31.20 MTLK.TSK 
32.0 DECnet/E V2.1 Documentation 
32ud DECnet/E V2.1 Release Notes 
32.2 DECnet/E V2.0 System Manager's Guide 
32.3 DECnet/E V2.0 Network Programming in BASIC-PLUS and 
BASIC-PLUS-2 
32.4 DECnet/E V2.0 Network Programming in MACRO 
3265 DECnet/E V2.0 Network Programming in FORTRAN 
32.6 DECnet/E V2.0 Network Programming in COBOL 
S257 DECnet/E V2.0 System User's Manual 
32.8 DECnet/E V2.0 Installation Manual 
33.0 (Reserved) 
34.0 (Reserved) 
35.0 (Reserved) 
36.0 DECmail-11 v2.0 
36.1 Package Notes 
37.0 (Reserved) 
38.0 (Reserved) 
39.0 (Reserved) 
40.0 RPG V8.8 


40.1 Package Notes 


(Reserved) 
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42.0 
43.0 
44.0 


45.0 
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46.0 
46.1 


47.0 
A7.1 


48.0 
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49.0 
49.1 


50.0 
50.1 
50.02 
50.3 
50.4 


51.0 
Sobel 
SiaZ 
51.3 
51.4 
51:35 
5146 


SLa7 
5148 


52.0 
S21 
Oewe 
D263 
92.4 
spare 
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53.0 
5341 
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Package Notes 


INDENT V1.4 
Package Notes 


ADE V2.4 
Package Notes 


BASIC-PLUS-2 V2.3 
Package Notes 


DATATRIEVE-11 V3.1 
Package Notes 


KMC Drivers and Utilities 
Package Notes 
IBM Interconnect (II) Driver 


KMC11 (XK) Driver 
KMCUT 


RSTS/E 3271 Protocol Emulator V2.1 
Package Notes 

(Reserved) 

3271 Microcode (CRAM) 

3271 Microcode (RAM) 

MTO 
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(AA-H474C-TC) 
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DIBOL Interface 


RSTS/E High Performance 2780/3780 Emulator V1.1 


Package Notes 

2780 Microcode (CRAM) 
2780 Microcode (RAM) 

3780 Microcode (CRAM) 
3780 Microcode (RAM) 

RJESPL 


RSTS/E 2780/3780 High Performance Emulator V1.1 Release 


Notes (AA-J458B-TC) 


RSTS/E High Performance 2780/3780 Emulator User's Guide 


(AA-J177A-TC) 


SORT/MERGE V3.0 
Package Notes 
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54.0 
54.1 


55.0 
heat 


56.0 
56.1 


57.0 
BPiod 


58.0 
98.1 


59.0 


60.0 
60.1 


61.0 


62.0 
62.1 


63.0 
64.0 
65.0 


66.0 
66.1 


67.0 


68 .0 
68.1 


69.0 
69.1 


70.0 
70.1 
70.2 
70.3 


71.0 
Tle 
71.2 


ADE V2.3 
Package Notes 


FORTRAN IV V2.6 
Package Notes 


COBOL-81 V2.3 
Package Notes 


FORTRAN-77 V5.0 
Package Notes 


FORTRAN-77 DEBUG V1.0 
Package Notes 


(Reserved) 


Message Router V1.0 
Package Notes 


(Reserved) 


PLXY-11 V1.3 
Package Notes 


(Reserved) 
(Reserved) 
(Reserved) 


PRO IV V1.0 
Package Notes 


(Reserved) 


MENU-11 V2.0 
Package Notes 


DECword/DP V1.2 
Package Notes 


COBOL-11 V4.4 

Package Notes 

COBOL Compiler - NON-CIS 
COBOL Compiler - CIS 


DMS-500 V2.1 
Release Notes 
DMS-500 User's Guide 
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Page 


These are the component numbers for the ISAM and RAM package: 


da 
11,4 
pes: 
71.6 
a 
71.8 
TAe9 
71.10 
ren 
gga 
Tle 
71.14 
ip Paks 
11416 
Tiel 7 
tials 


These 
71.19 
71220 
Pa ee | 
71.22 
Ths? 3 
71.24 
VL 25 
72.0 


73.0 
13s 


74.0 


75.0 
oe 


76.0 
76.1 


77.0 
78.0 
12:0 
80.0 


81.0 
81.1 


DMSFSS.BAS 
DMSISO.BAS 
DMSRAO. BAS 
DMSISR.BAS 
DMSISC.BAS 
DMSRAR. BAS 
DMSISA.BAS 
DMSRAA. BAS 
DMSFSU.BAS 
DMSFSX.BAS 
DMSUTL. BAS 
IAMGEN. BAS 
IAMCRI.BAS 
IAMDMP. BAS 
IAMVFY.BAS 
IAMFNS.BAS 


are the component numbers for the DSORT package: 


DSORT. BAS 

DSORTD. BAS 
DSORTF. BAS 
DSORTX. BAS 
DSORTS.BAS 
DSORTM. BAS 
DSORTO.BAS 


(Reserved) 


DIBOL V5.1A 


Package Notes 


(Reserved) 


RMS-11 V2.0 


Package Notes 


DIBS-11/CTS500 V1.0 
Package Notes 


(Reserved) 
(Reserved) 
(Reserved) 


(Reserved) 


DECgraph-1l V1.2 
Package Notes 


RSTS/E V9.0 Maintenance Notebook, June 1985 Page 2-13 
Component.Subcomponent Assignments ; 


82.0 (Reserved) 

83.0 (Reserved) 

84.0 (Reserved) 

85.0 (Reserved) 

90.0 User Assigned Components - For Development Use 
90.1 Package Notes 

sear User Assigned Components - For User Use 
oO 


99.0 
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3.0 Software Performance Reports 


Each new installation is provided with Software Performance Report 
(SPR) forms. The SPR form allows you to suggest enhancements to, or 
report problems with DIGITAL software or documentation. When you 
discover a problem, complete an SPR and mail it to the local SPR 
Center (see the inside back cover of the SPR form). 


Responses will be sent to the name and address appearing on the form. 
You can obtain additional SPR forms by writing to the local SPR 
Center. 

SPR response service iS provided at no charge for one year after 
installation and may be continued by subscription thereafter. 

3.1 Software Performance Report Guidelines 

These guidelines for RSTS/E SPR completion ensure that adequate 


information is included to prevent delays in processing. 


For all types of actual or suspected software problems, the following 
should be included with the SPR: 


1. A complete description of the problem. 
2. The CPU type. 

3. The system disk type. 

4, The amount and type of memory. 


5. If possible, a simple program or procedure which can be 
used to reproduce the problem. 


6. Any additional information which you may think is 
relevant. 


For problems associated with the RSTS/E monitor or crash analysis 
package (ANALYS), also include: 


1. The crash dump printed by  ANALYS (which includes 
annotations, a listing of the symbol table, and a list of 
all installed patches). 


2. A machine readable copy (preferably a backup on 9-track 
magnetic tape) of your monitor and CRASH.SYS file. Your 
media will be returned with your SPR answer. 
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When submitting an SPR concerning a DIGITAL-Supplied utility 


also include: 


1. The name of the CUSP. 
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(CUSP), 


2. A "RUN" of the CUSP which displays the header line, 


version number, and the problem which is occurring, 


possible. 


3. A list of any optional feature patches installed. 


if 


4, Whether the program runs under BASIC-PLUS (.BAC version) 


or RSX (.TSK version). 


5. A listing of the account(s), and the account(s) 


attributes, in which the problem occurs. 


6. A. complete listing of the CUSP (preferably on magnetic 
tape) if your installation has made any non-standard 


changes. 
7. \Listings of all relevant input and output files. 


NOTE 


No SPR, monitor or CUSP, will be considered unless ALL 


relevant Mandatory patches published to date have 


been 


applied. Before submitting an SPR, you should review 


the relevant section(s) of the Maintenance Notebook, 


to 


ensure that ALL Mandatory updates and patches to the 


program or package have been installed. 
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4.0 Procedures for Updating RSTS/E Software 


This section briefly describes the updating procedures to be used for 
maintenance of RSTS/E V9.0. The procedures to be_ followed for 
updating the monitor and system programs when installing a new RSTS/E 
system are described in the RSTS/E System Installation and Update 
Guide. The procedures for updating the software as part of normal 
system maintenance are described in the RSTS/E System Manager's Guide. 


Most corrections to RSTS software are done by replacing the affected 
components with updated versions distributed on the next release of 
RSTS/E (V9.1, v9.2, etc.) . These replacement modules are 
automatically installed as part of the RSTS installation and update 
process. 


In cases where a critical problem is discovered, DIGITAL will publish 
an article in the RSTS/E Software Dispatch describing the problem and 
suggesting possible work-arounds until the module is replaced in the 
next V9 update release. If no reasonable work-arounds are available, 
a patching procedure will be included in the article so you can 
correct the defective module. Step-by-step instructions on how to 
apply the patch will be included. 


Unless otherwise stated, Mandatory patches published in the RSTS/E 
Software Dispatch should be installed as soon as possible. Since not 
all Mandatory patches apply to every installation, patches to unused 
Or optional components will fail when you attempt to apply them. In 
such cases, the patch article will describe how the patch will fail if 
it does not apply to your system. 


Be sure to file and maintain all Dispatch articles, even for unused 
components. Your site may choose at some future time to. install 
additional components; these components will then have to be brought 
up to the latest support level. 


Some Dispatch articles may include "Feature" patches, allowing you’ to 
modify a component to enable an optional feature of that component. 
These Feature patches are optional and are not required to keep a 
component at itsS current support level. However, if you encounter 
problems in a component containing optional features, you must- report 
which Feature patches have been installed when submitting a Software 
Performance Report (SPR). 
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4,1 Monitor Patching 


Normally, problems discovered in a RSTS/E monitor are corrected by 
replacing the defective component during the installation and update 
procedure. You must rebuild your system's monitor each time you 
receive a new RSTS/E update to install any corrections made to the 
monitor components. 


If it should become necessary for you to apply a patch to- your 
system's monitor, the RSTS/E Software Dispatch article describing the 
problem will also explain how to apply the patch. Normally, changes 
to the RSTS/E monitor are made using the off-line PATCH option of 
INIT.SYS or the on-line program SONLPAT.SAV. General descriptions of 
these patching tools and how to use them are included in the RSTS/E 
System Installation and Update Guide and the RSTS/E System _Manager' 


Guide. | 
The patching article will include specific instructions on how to 
apply the patch. The expected dialogue will be shown in the article 
as it should appear when you install the _ patch. If any deviation 
occurs, you should immediately: 

1. Halt the patching process 

2. Restore any changes already made to their former values 


3. Determine where the discrepancy occurred 


4,2 Commonly Used System Program (CUSP) Module Replacement 


Like the monitor, corrections to individual RSTS/E programs are made 
by replacing the defective module with a replacement from the v9.0 


Installation Kit. These replacement modules are automatically 
installed whenever you install or update the package containing the 
replacement program. For example, if a replacement module for the 


HELP.TSK program is included on a RSTS/E installation kit, then that 
module will replace the copy of HELP.TSK on your system whenever you 
install or update the HELP package. 


Note that you no longer need to copy replacement modules for _ the 
RSTS/E CUSPs to disk with PATCPY before beginning the installation or 
update. All replacement modules for bundled software will 
automatically be applied whenever you install or update your RSTS/E 
software. 
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4.3 Installation Kits 


RSTS/E Installation Kits contain the minimal software necessary to 
create a RSTS/E system, as well as replacement modules and/or patches 
for software supported under RSTS/E V9.0. The RSTS/E V9.0 Installation 
Kit contains all patches published in the RSTS/E V9.0 Maintenance 
Notebook and in the RSTS/E V9.0 Software Dispatch Review. Each 
subsequent RSTS/E Installation Kit (V9.1, V9.2, etc.) will contain all 
of the components from the previous installation kit, plus any new 
modules and/or patches published in the RSTS/E Software Dispatch. 
Thus, you only need the most recent RSTS/E installation kit to update 
your system to the current revision level. 


Note that in some cases, patches previously published in the RSTS/E 
Software Dispatch will become obsolete, since the correction provided 
by the patch will be included in the replacement module itself. In 
such cases, a new Dispatch article will be published to supersede _ the 
previous patch article. 


The cumulative index published in the RSTS/E Software Dispatch will 
indicate which installation kit (V9.0, V9.1, etc.) first contained a 
patch or module replacement. 


Procedures for using the installation kit to update standard RSTS/E 
software can be found in the RSTS/E System Installation and Update 
Guide. Procedures for updating optional layered software are usually 
found in the appropriate installation manual for the product. 
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4,4 Patches and Replacement Modules for Optional Layered Products 


The RSTS/E V9.0 Installation Kit also contains patches and replacement 
modules for optional layered products. Information on how to update 
layered products will be included with each installation kit in the 
file UPDATE.DOC. This file is automatically copied to the UPDATES 
account on your system whenever you install the UPDATE package during 
a system installation or update. Be sure to read the information in 
the UPDATE.DOC file before updating any RSTS/E layered product. 


Note that PBUILD is no longer included with RSTS/E. To update those 
layered products that used PBUILD in the past, you must now mount the 
Original layered product distribution kit and use the BUILD/PATCH or 
PATCH option of BUILD.TSK. 


To install layered product patches or replacement modules, you must 
first transfer all of the patches, replacement modules, and command 
files for that product to a patch account (PATCHS by default) on your 
system. This step iS now required for both disk and tape installation 
kits. — 


TO transfer layered product update components from the RSTS/E 
installation kit to the PATCHS account, perform either of these steps: 


1. During the installation procedure, type "YES" to the prompt: 


Do you want to transfer the layered product update 
components from the Installation kit ? 


2. Invoke the DCL "copy update” command procedure by typing the 
DCL command line: 


$ @{0,1]COPYUP "package name" 


where "package name" is the name of the layered product you 
want to update. . 


For more information on updating a layered product, please read the 
file UPDATES:UPDATE.DOC included with the UPDATE package on all RSTS/E 
V9.0 Installation Kits. 
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5.0 Software Product Descriptions (SPDs) 
and . 
Option Bulletins 


5.1 Software Product Descriptions (SPDs) 


Periodically, new or revised Software Product Description (SPD) 
bulletins will appear in the RSTS/E Software Dispatch for various 
software products marketed by DIGITAL. This section of the notebook 
is provided aS a convenient place to file these SPDs for future 
reference. 


Every SPD has a unique number, for example: 
SPD 13.1.20 
This number appears on the first page of the SPD bulletin, at the far 


right hand side of the PRODUCT NAME: line. 


Note that the last part of the SPD number is the revision level, with 
0 being assigned for original issues of SPDs. 


5.2 Option Bulletins 


Periodically, new or revised Option Bulletins will appear in the 
RSTS/E Software Dispatch for various products marketed by DIGITAL. 
This section of the notebook is provided as a convenient place to file 
these bulletins. There is no filing scheme for option bulletins. 
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6.0 RSTS/E Articles 


Section 6.0 is the repository for all RSTS/E articles. This section 
will include problem solutions, optional "Feature" patches, 
documentation errata, programming hints, and tips for better operation 
of RSTS/E. 


Anyone who installs a RSTS/E system (whether on-line under time 
sharing or as the initial version of the system) should become 
familiar with these articles. This should be a continuing process of 
education as sub-sections are added and updated. 


The section which follows is an index to all articles included in the 
Original RSTS/E Maintenance Notebook. This index will be updated 
monthly as new articles are published in the RSTS/E Software Dispatch. 
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RSTS/E V9.0 COMPONENT SUMMARY 


This table lists all of the software components included with RSTS/E 
v9.0. It does not include optional layered product components or 
temporary modules created during installation. Modules belonging to 
an optional package included with RSTS/E will only be present if you 
choose to install that package on your system. 


Listed with each module is its current version/edit level, its 
standard protection code, and its expected location on your system. 


Note that file protection codes play a critical role in the overall 
security of your system. You should not change the protection code of 
any file included with RSTS/E unless directed to do so. Changing a 
file's protection code to a different value may compromise security or 
cause the program to fail in unpredictable ways. 


This article will be superseded whenever a component is added, deleted 
or replaced in a later release of RSTS/E. 


System Installation and Update 


Component Edit Prot Location 
BPLGEN.SAV v9.0-14 <124> SYSGENS: 
BUFCHK.TSK v9.0-14 <124> SYSGENS: 
COPYUP.COM V9.0-14 <104> Re ae 
INSTAL.COM v9.0-14 <104> [0,1] 
SYSGEN.SAV V9.0-14 <124> SYSGENS: 
UPDATE .COM V9.0-14 <104> COG de] 
System Files 
Component Edit Prot Location 
BACKUP.TSK v9.0-14 <104> [0,1] 
CSPLIB.LIB V9.0-14 <60> [0,1] 
ERR .ERR Vv9.0-14 <40> [0,1] 
INIT .SYS V9.0-14 <60> Oy 
LOGIN .COM v9.0-14 <104> [0,1] 
RECOVR.COM v9.0-14 <124> LO. 1] 
START .COM v9.0-14 <124> EOy 24 
SYSGEN.SIL V9.0-14 <60> [0,1] 
SYSINI.COM Vv9.0-14 <124> CO a4 
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HELP 
Component Edit Prot Location 
HELP .TSK v9.0-14 <232> HELPS: 
- .~HLP v9.0-14 <40> HELPS: 

TECO 
Component Edit Prot Location 
CRTRUB.MAC V39.00 <60> TECOS: 
CRTRUB.OBJ V39.00 <60> TECOS: 
FMTMAC. TEC V39.00 <104> TECOS: 
FMTMAC.TES V39.00 <40> TECOS: 
GEXIT .OBJ V9.0-39 <60> TECOS: 
LOCAL .TEC V39.00 <104> TECOS: 
LOCAL .TES V39.00 <40> TECOS 
SCREEN. OBJ V39.00 <60> TECOS: 
SCRINS.OBJ V39.00 <60> TECOS: 
SCROLL.OBJ V39.00 <60> TECOS: 
SEARCH. TEC V39.00 <104> TECOS: 
SEARCH. TES V39.00 <40> TECOS: 
SQU ~TEC V39.00 <104> TECOS 
SQU - TES V39.00 <40> TECOS 
TECKBM. TEC <104> TECOS: 
TECKBM. TES <40> TECOS 
TECO .DOC v40 <40> TECOS 
TECO .INI V03.00 <40> TECOS 
TECO .RTS v40.00 <60> TECOS: 
TECO .TEC V40.00 <104> TECOS 
TECO .TES v40.00 <40> TECOS 
TECOIN.TES v03.00 <40> TECOS: 
TECOLB.OBJ <60> TECOS: 
TECORN. DOC v40 <40> TECOS: 
TYPE .TEC V39.00 <104> TECOS: 
TYPE .TES V39.00 <40> TECOS: 
VTEDIT.DOC V39.00 <40> TECOS: 
VTEDIT.TEC V39.00 <104> TECOS: 
VTEDIT.TES V39.00 <40> TECOS: 
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System Library 


Component Edit Prot Location 

ACTMGR. TSK v9.0-14 <232> (132) 

ATPK .TSK v9.0-14 <232> f1,2] 

AUTOED. TSK V9.0-14 <124> [1,2] (see note 1) 
BUILD .TSK v9.0-14 <124> [1,2] (see note 1) 
COMMON .MAC v9.0-14 <40> [1,2] 

CPATCH.TSK V9.0-14 <124> [1,2] (see note 1) 
CSPCOM.TSK v9.0-14 <124> [1,2] (see note 1) 
DIRECT.TSK v9.0-14 <232> [1,2] 

DSKINT.TSK v9.0-14 <124> [1,2] 

ERR .STB vV9.0-14 <40> [1,2] 

FILCOM.TSK v9.0-14 <104> [1,2] 

LOGIN .TSK V9.0-14 <232> p12 | 

LOGOUT. TSK v9.0-14 <232> [1,2] 

MAKSIL.TSK v9.0-14 <104> Er 2 

ONLCLN.TSK v9.0-14 <232> [1,2] 

ONLPAT. SAV V9.0-14 <104> [ted 

PIP . SAV v9.0-14 <232> [1,2] 

PLEASE. TSK V9.0-14 <232> [1,2] (see note 2) 
QUE .TSK v9.0-14 <232> [1,2] (see note 2) 
REORDR. TSK v9.0-14 <124> [1,2] 

SAVRES. SAV v9.0-14 <124> to 

SHUTUP. TSK v9.0-14 <232> [1,2] 

SWITCH.TSK v9.0-14 <232> P24 

SYSTAT.TSK v9.0-14 <232> [1,2] 

TERMGR. TSK v9.0-14 <232> [1,2] 

UTILTY.TSK v9.0-14 <124> [1,2] (see note 1) 
UTLMGR. TSK V9.0-14 <232> [1,2] 

Note 1 


These programs are "dispatcher" programs that chain to 
the actual program located in the UPDATES account. 


Note 2 


These programs are "dispatcher" programs that chain to 
the actual program located in the OPSERS account. 
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Auxiliary Library 


Component Edit Prot Location 
BPCREF.TSK v9.0-14 <104> AUXLIBS: 
BPCRF1.TSK v9.0-14 <104> AUXLIBS: 
COPY .TSK v9.0-14 <104> AUXLIBS: 
DISPLY.TSK v9.0-14 a232> AUXLIBS: 
DSKCVT.TSK v9.0-14 <124> AUXLIBS: 
FIT TSK v9.0-14 <124> AUXLIBS: 
FLINT .TSK v9.0-14 <104> AUXLIBS: 
GRIPE .TSK vV9.0-14 <232> AUXLIBS: 
ODT - TSK Vv9.0-14 <104> AUXLIBS: 
PMDUMP. TSK V90-14 <104> AUXLIBS: 
QUOLST.TSK v9.0-14 <232> AUXLIBS: 
RUNOFF .TSK v9.0-14 <104> AUXLIBS: 
TALK .TSK v9.0-14 <232> -AUXLIBS: 
Error Control 
Component Edit © Prot Location 
ANALY1.TSK v9.0-14 <124> ERRORS: 
ANALY2.TSK v9.0-14 <124> ERRORS : 
ANALY3.TSK V9.0-14 <124> ERRORS: 
ANALYS.TSK v9.0-14 <124> ERRORS: 
ERRCPY.TSK v9.0-14 <232> ERRORS: 
ERRDAT.FIL v9.0-14 <60> ERRORS: 
ERRDET.TSK v9.0-14 <232> ERRORS: 
ERRDIS.TSK v9.0-14 <232> ERRORS: 
ERRINT.TSK v9.0-14 <232> ERRORS: 
MSCPER. FIL v9.0-14 <60> ERRORS: 
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RESTOR 
Component Edit Prot Location 
BACCOM. TSK v9.0-14 <252> RESTORS : 
BACCON. TSK v9.0-14 <252> RESTORS : 
BACDIR.TSK v9.0-14 <252> RESTORS : 
BACDSK. TSK v9.0-14 <252> RESTORS : 
BACENT. TSK v9.0-14 <252> RESTORS: 
BACFRM. TSK v9.0-14 <252> RESTORS: 
BACLAB. TSK v9.0-14 <252> RESTORS: 
BACLOD. TSK Vv9.0-14 <252> RESTORS : 
BACLST.TSK v9.0-14 <252> RESTORS : 
BACMNT. TSK Vv9.0-14 <252> RESTORS: 
BACKUP .HLP v9.0-14 <60> RESTORS : 
BACKUP. PRM v9.0-14 <60> RESTORS : 
RESTOR. TSK v9.0-14 <252> RESTORS : 

Operator Services (OPSER) 
Component Edit Prot Location 
BATCH .DCD v9.0-14 <60> OPSERS: 
BATCH .TSK v9.0-14 <232> OPSERS: 
BATDCD. TSK v9.0-14 <232> OPSERS: 
BATDEC. TSK v9.0-14 <232> OPSERS: 
BATIDL.TSK vV9.0-14 <232> OPSERS; 
BATRUN. TSK v9.0-14 <232> OPSERS: 
CHARS .QUE v9.0-14 <60> OPSERS: 
OPSER .TSK v9.0-14 <232> OPSERS: 
OPSRUN.TSK v9.0-14 <232> OPSERS: 
PLEASE.TSK v9.0-14 <232> OPSERS: (see note) 
QUE .TSK v9.0-14 <232> OPSERS: (see note) 
QUEMAN. TSK Vv9.0-14 <232> OPSERS: 
QUMRUN. TSK v9.0-14 <232> OPSERS: 
SPLIDL.TSK v9.0-14 <232> OPSERS: 
SPLRUN. TSK v9.0-14 <232> OPSERS: 
SPOOL .TSK v9.0-14 <232> OPSERS: 

Note 


These programs have corresponding "dispatcher" programs 


in the 


system 


library (S$) 


account, 


for 


backward 


compatibility with programs or command procedures that 
reference these programs in the $ account. 
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Print/Batch Services (PBS) 


Component Edit Prot Location 
FORMS .SYS v9.0-14 <40> PBSS 

PBSMGR. TSK v9.0-14 <232> PBSS: 

PBS -SYS Vv9.0-14 <188> PBSS: 

PBS . TSK v9.0-14 <232> PBSS 

PBSERR.ERR v9.0-14 <40> PBSS: 

Unsupported Software 

Component Edit Prot Location 
BPDA BAS V9.0-14 <60> UNSUPPS: 
BPDA TSK v9.0-14 <104> UNSUPPS: 
B2CREF.DOC v9.0-14 <40> UNSUPPS: 
B2CREF.HLP v9.0-14 <60> UNSUPPS: 
B2CREF.TSK v9.0-14 <104> UNSUPPS: 
CMTAB .MAC v9.0-14 <60> UNSUPPS: 
COMND .MAC v9.0-14 <60> UNSUPPS: 
CONNEC. BAS v9.0-14 <60> UNSUPPS: 
CONNEC.TSK V9.0-14 <104> UNSUPPS: 
DIALER.BAS v9.0-14 <60> UNSUPPS: 
DIALER. DOC v9.0-14 <60> UNSUPPS: 
DIALER.TSK v9.0-14 <104> UNSUPPS: 
DSKDMP. BAS v9.0-14 <60> UNSUPPS: 
DSKDMP.HLP v9.0-14 <60> UNSUPPS: 
DSKDMP.TSK v9.0-14 <124> UNSUPPS: 
DSKPEK.OBJ v9.0-14 <60> UNSUPPS: 
DUMP .SAV v9.0-14 <104> UNSUPPS: 
EMTCPY.BAS V9.0-14 <60> UNSUPPS: 
EMTCPY.TSK v9.0-14 <124> UNSUPPS : 
ERMSG .MAC v9.0-14 <60> UNSUPPS: 
FLOAT .BAS v9.0-14 <60> UNSUPPS: 
FLOAT .TSK V9.0-14 <124> UNSUPPS: 
FMTCM .MAC v9.0-14 <60> UNSUPPS: 
HYPHEN.MAC v9.0-14 <60> UNSUPPS : 
INDEX .MAC v9.0-14 <60> UNSUPPS : 
LOSTAT. BAS v9.0-14 <60> UNSUPPS: 
LOSTAT.TSK v9.0-14 <124> UNSUPPS: 


RSTS/E Maintenance Notebook, June 1985 


RSTS/E V9.0 
RSTS/E V9.0 General Notes 
System Notes 


Seq 0.1.1N 


1 Of. Ad 


Unsupported Software 


Component Edit ~ Prot Location 
MEMORY. BAS v9.0-14 <60> UNSUPPS: 
MEMORY. TSK v9.0-14 <124> UNSUPPS: 
MONEY .BAS v9.0-14 <60> UNSUPPS: 
MONEY .TSK v9.0-14 <124> UNSUPPS: 
PINDX .MAC v9.0-14 <60> UNSUPPS: 
QSTATS.B2S v9.0-14 <60> UNSUPPS: 
OSTATS . DOC v9.0-14 <60> UNSUPPS: 
QOSTATS.TSK v9.0-14 <124> UNSUPPS: 
RNCMD .MAC v9.0-14 ~ <60> UNSUPPS: 
RNFIO .MAC v9.0-14 <60> UNSUPPS: 
RNPRE .MAC v9.0-14 <60> UNSUPPS: 
RNO - RNO v9.0-14 <60> UNSUPPS: 
RNO - TSK Vv9.0-14 <104> UNSUPPS: 
RNOBLD.CMD v9.0-14 <60> UNSUPPS: 
RNOBLD.ODL v9.0-14 <60> UNSUPPS: 
RNORSX.MAC v9.0-14 <60> UNSUPPS: 
RSTSFL. DOC V9.0-14 <60> UNSUPPS: 
RSTSFL.HLP v9.0-14 <60> UNSUPPS: 
RSTSFL.OBJ v9.0-14 <60> UNSUPPS : 
RSTSFL.OLB v9.0-14 <60> UNSUPPS: 
RUNOFF .MAC v9.0-14 <60> UNSUPPS: 
SRCCOM. SAV Vv9.0-14 <104> UNSUPPS: 
START .MAC v9.0-14 <60> UNSUPPS: 
STATUS.B2S v9.0-14 <60> UNSUPPS: 
STATUS.TSK vV9.0-14 <124> UNSUPPS: 
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Layered Product Update 


Component Edit Prot Location 

AUTOED.TSK V9.0-14 <124> UPDATES: (see note) 
BUILD .TSK v9.0-14 <124> UPDATES: (see note) 
CPATCH. TSK v9.0-14 <124> UPDATES: (see note) 
CSPCOM. TSK V9.0-14 <124> UPDATES: (see note) 
CSPCOM.OLB V9.0-14 <60> LB: 

UPDATE.DOC v9.0 <60> UPDATES : 

UTILTY.TSK v9.0-14 <124> UPDATES: (see note) 

Note 


These programs have corresponding "dispatcher" programs 
in the system library ($) account, for backward 
compatibility with programs or command procedures’ that 
reference these programs in the $ account. 


Device Test 


Component Edit Prot Location 
CPEXER.TSK V9.0-14 <124> TESTS 
CPUTST.TSK Vv9.0-14 <124> TESTS 
DSKSEK.TSK V9.0-14 <124> TESTS 
DTEXER. TSK V9.0-14 <124> TESTS 
DXEXER. TSK V9.0-14 <124> TESTS 
DSKEXR.TSK V9.0-14 <124> TESTS 
KBEXER. TSK V9.0-14 <124> TESTS 
LPEXER.TSK V9.0-14 <124> TESTS: 
MTEXER. TSK V9.0-14 <124> TESTS 
PPEXER.TSK V9.0-14 <124> TESTS: 
PREXER. TSK V9.0-14 <124> TESTS: 
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DCL Runtime System and Utilities 


Component Edit Prot Location 
BP2 . LNK v9.0-14 <40> [1,2] 
C81 . LNK v9.0-14 <40> [1,2] 
DCL .RTS v9.0-14 <232> [0,1] 
DCLUTL.TSK v9.0-14 <232> [1,2] 
DIBOL .LNK v9.0-14 <40> [1,2] 
DMS . LNK v9.0-14 <40> [1,2] 
F77 . LNK v9.0-14 <40> [4.2 
PRELIN.TSK v9.0-14 <232> [1,2] 
RSX11 .LNK v9.0-14 <40> [ed 
RSX Runtime System and Utilities 

Component Edit Prot Location 
CRF .TSK V05.03c <104> [1,2] 
LBR . TSK v06.00 <104> Cts 2. 
MAC TSK V05.03c <104> [1,2] 
ODT OBJ 09.009 <40> LB: 
ODTID .OBJ DO1.01 <40> LB: 

PAT TSK v02.02 <104> ea 
RSX RTS v9.0-14 <60> FO 4 
RSXMAC. SML <40> LB: 

STK .TSK 09.009 <104> [1,2] 
SYSLIB.OLB <40> LB: 

TKB TSK 09.009 <104> [1,2] 

RT-11 Runtime System and Utilities 

Component Edit Prot Location 
CREF SAV v05.03a <104> [1,2] 
HOOK .SAV v9.0-14 <124> SYSGENS: 
LIBR .SAV v04.00 <104> ees 
LINK .SAV V08.02R <104> [ae] 
MACRO .SAV v05.03c <104> [1,2] 
PAT SAV v04.00 <104> [1,2] 
RT11 .RTS v9.0-14 <60> [0,1] 
SILUS .SAV v9.0-14 <104> C2 
SYSLIB.OBJ <40> dy 2] 
SYSMAC.SML <40> [1,24 
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BASIC-PLUS Runtime System 


Component Edit | Prot Location 
BASIC .RTS  —-V9..0-14 — <60> [0,1] 
EDT V3.0 
Component Edit Prot Location 
EDT .LIB V3.0 <60> EDTS: 
EDT - TSK V3.0 <104> EDTS: 
EDT100.DOC v3.0 <40> EDTS: 
EDT200.DOC V3.0 -.  <40> EDTS: 
EDT52: .DOC V3.0 <40> EDTS: 
EDTHEL.HLP V3.0 . <40> LB: 
EDTKIT.DOC V3.0 <60> EDTS: 
SORT V3.0 
Component Edit Prot Location 
MGEFIL.ODL V3.0 — <40> LB: 
MGELIB.OLB V3.0 <40> LB: 
MGEREC.ODL V3.0. <40> LB: 
MGESHR.OLB V3.0. <40> LB: 
MGEUTL.TSK V3.0. <104> SORTS: 
SMRES .LIB V3.0 <60> [0,1] 
SMRES .STB V3.0 <4Q> LB: 
SMRES .TSK V3.0 <40> LB: 
SMSHR .ODL V3.0 <40> LB: 
SRTFIL.ODL V3.0 <40Q> LB: 
SRTLIB.OLB V3.0 | <40> LB: 
SRTREC.ODL V3.0 — <40> LB: 
SRTSHR.OLB V3.0 <40> LB: 
SRTTRN.TSK V3.0 <104> SORTS: 
SRTUTL. TSK V3.0 <104> SORTS: 
STMGFL.ODL V3.0 <40> LB: 


STMGRC.ODL V3.0 <40> LB: 
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RMS V2.0 

Component Edit Prot 
DAP11X.ODL V2.0 <40> 
DAPRES.LIB V2.0 <60> 
DAPRES.STB V2.0 <40> 
DAPRES. TSK V220 <40> 
DAPRLX.ODL V2.0 <40> 
RORMS1.MAC V240 / <4Q> 
RMS11 .ODL V2.0 <40> 
RMS11S.ODL V2.0 <40> 
RMS11X.ODL V2.0 <40> 
RMS12S.ODL v2.0 <40> 
RMS12X.ODL V2.0 <40> 
RMSBCK. TSK V2.000 <104> 
RMSCNV. TSK V2.001 <104> 
RMSDAP .OLB V2.0" <40> 
RMSDEF.TSK V2.000 <104> 
RMSDES .HLP V2.0 <40> 
RMSDES .TSK vV2.001 <104> 
RMSDSP. TSK V2.002 <104> 
RMSIFL.TSK V2.006 <104> 
RMSLBA.LIB V2.0 <60> 
RMSLBB.LIB V2<e0 <60> 
RMSLBC.LIB V2.0 <60> 
RMSLBD.LIB V2.0 <60> 
RMSLBE.LIB V2.0 <60> 
RMSLBF.LIB V2.0 <60> 
RMSLIB.OLB V2.0 <40Q> 
RMSMAC .MLB V2.0 <40> 
RMSRES.LIB V2.0 <60> 
RMSRES.STB V2.0 <40> 
RMSRES .TSK V2.0 | <40> 
RMSRLX.ODL V2.0 <40> 
RMSRST.TSK V2.002 <232> 


Location 
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ANNOUNCING RSTS/E VERSION 9.0 


RSTS/E V9.0, which has been in development for over 2 years, includes 
major enhancements to most of the RSTS/E system. These range from 
DCL-based integrated system and account management to streaming 
support for TU80 tape drives. Overall the enhancements in RSTS/E V9.0 
are focused on five major goals. These goals are: 


Complete and integrate the DCL-based user interface 
- Provide operational compatibility with VMS 
- New fast BACKUP with support for streaming tape drives 


- Improve system security 


Provide faster, easier installation and update 


PRODUCT DESCRIPTION 


DCL Command File Processing 


The new RSTS/E DCL command file processor is based on the VMS model 
and is fully integrated with the RSTS/E system at command level. This 
feature allows users to define command procedures, define their own 
commands on a per user basis and automate many user and system 
management tasks. It 1s subset compatible with VMS command file 
processing, SO many command procedures can be moved from a RSTS/E 
system to a VMS system and back again without modification. This can 
also help to reduce the level of complexity required to manage VMS and 
RSTS/E systems kept in the same area or involving the same _ people, 
Since many functions can be accessed by using similar command 
procedures. 


The DCL command processor is a text processor whose performance is 
generally slower than most other high-level languages. For this 
reason, you should consider performance when deciding what langauge is 
best suited to a particular task. DCL should be viewed as a "command 
level" language that best handles the execution and control of system 
or user commands. 


RSTS/E Maintenance Notebook, June 1985 


RSTS/E V9.0 Seq 0.1.2 N 
RSTS/E V9.0 General Notes | 

System Notes | 2 of 6 
Logging In 


One impact of DCL command processing performance concerns logging in. 
When logging in on V9.0, the LOGIN program will chain to the 
system-wide login command file, LOGIN.COM, located in account [0,1] on 
the system disk. This file contains commands to be performed for all 
users logging in to the system. Users in turn can create their own 
LOGIN command files to define new commands, read mail, assign 
logicals, or perform any other task as part of the login sequence. 


Some tasks that were previously done in the LOGIN program are now done 
in the system login command procedure. For example, printing of the 
SNOTICE.TXT file at your terminal is now handled by the system 
LOGIN.COM file, rather than the LOGIN program. = 


Because login command files are normally executed "Silently" (no 
echoing of the commands at your terminal), the login sequence in V9.0 
may appear slower than in the past. This will, of course, depend on 
the size of the system login command file and each user's login 
command file, as well as system load, resources, etc. 


Login delays were a recognized problem during the V9.0 field test. 
Since the start of field test, much effort went into optimizing the 
system login command file to minimize its processing time. 


Because of these efforts, most users logging in to a light- or 
medium-loaded V9.0 system with the distributed system LOGIN.COM file 
will notice only a slight delay (less than five seconds) between 
entering their password and the display of the DCL prompt. On 
heavily-loaded systems, the delay may be longer. 


DIGITAL is investigating ways of making DCL command processing faster 
in the future. This effort will further reduce any delays during 
login. 


DCL is Extended to the Entire RSTS/E System 


In past releases of RSTS/E users were required to learn many different 
utilities and their syntax to fully utilize the power of the RSTS/E 
system. In RSTS/E V9.0 there are over 100 modifications to DCL which 
solve this problem. These range from new qualifiers on existing 
commands to the addition of entirely new commands which add major new 
capabilities to the RSTS/E system. 
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There are many illustrations of V9.0 modifications thoughout the 
RSTS/E V9.0 system: 


- The new DCL based integrated account management 
function which replaces many separate utilities 
such as UTILTY, MONEY and REACT. 


- The new batch processor uses DCL command files 
and executes them at the time specified by the user. 


- The new BACKUP function iS accessed using DCL commands. 


New BACKUP Utility Increases Capabilities and Throughput 


The new BACKUP utility includes four main areas of improvement: 
increased capabilities, backup sets which are in VMS compatible 
format, support for the new Asynchronous I/O directives, and support 
for streaming tape drives such as the TU80. 


Writing and reading backup sets in VMS compatible format makes it easy 
to transfer data from a PDP-1ll to a VAX and back again. 


Full streaming support for streaming tape drives such as the TU80 will 
allow users to backup their systems in a fraction of the time which is 
now required. It also lays the groundwork for support of future 
streaming tape drives. 
Security Enhancements 
Since RSTS/E is used primarily in the commercial environment, RSTS/E 
users are particularly concerned with security. Steady progress was 
made in this area in the course of past releases; however, RSTS/E 
v9.0 has moved a giant step forward with five major areas of 
improvement: 

- Multiple privilege attributes by account 

- Longer passwords 

- Hashed passwords 


- System password 


- Enhanced disk quota checking and enforcement 
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Multiple privilege attributes by account eliminates the use of "all or 
nothing" accounts and implements the VMS model of privilege 
attributes. Using this model, users are given only those privileges 
which they require and no others. Their account number (PPN) no 
longer denotes a privilege level. This gives the system manager 
tighter control over what users are allowed to do on the system. 


Passwords have been lengthened from a maximum of 6 characters to 14 
characters. Optionally by account, passwords can be set up so that 
they are no longer available for lookup and are hashed so that they 
can not be retrieved. 


Another feature of the new security system is the use of captive 
accounts. These are accounts which are setup to startup a program, 
such as a menu of selectable options or an application like word 
processing, and when the user exits from the program RSTS/E logs’ the 
user out of the system. 


Another aspect of security is the ability to control system resources. 
RSTS/E V9.0 features increased control of disk usage through logged in 
and logged out quotas. This allows the system manager to allocate and 
control disk resources effectively. 


Conversion to these new approaches can be done either gradually or all 
at once depending on the needs of the system. 


Separate I&D Space Support for User Programs 


Standard 16-bit addressing allows user programs to grow to 32KW before 
overlaying is required. With RSTS/E V9.0 users can now address’ upto a 
maximum of 64KW through the use of separate Instruction and Data (I&D) 
space. This will lead_to improved performance and lessen overlay 
complexity. Currently the languages that support I&D space are 
BASIC-Plus-2 V2.3, Macro (MAC), and Fortran 77. 


Virtual Disk 


System managers can allocate a portion of contiguous unused memory to 
be a virtual disk. This memory is considered to be a file-structured 
device and can be accessed by user programs in the same way that other 
disks are accessed except that data accesses occur at memory speeds 
rather than disk speeds. 
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Enhanced 8-Bit Character Support 


The RSTS/E monitor has been enhanced to support 8-bit characters such 
as the multinational character set. Many of the CUSPs will now accept 
8-bit characters but may not fully use them. BASIC-PLUS has not’ been 
enhanced to include this support. 


Autobaud Detection 

Autobaud detection support includes baud rates from 110 to 9600 baud. 
Speeds can be detected for dial-up and directly connected terminals. 
Faster, Easier Installation and Updating 

The installation and SYSGEN processes have been made far simpler and 
include defaults and help that was not available in previous releases. 
When installing a system (after the first time) previous answers’ can 
be automatically used as input into the installation process. In some 
cases installation and updating time can be reduced by 80%. 

Memory Requirements 

Due to the greatly enhanced capabilities, the memory required has also 
increased. The increase is not extreme and PDP 11/34 systems will 
continue to be supported, but users will have less space to run _ jobs 
than they do when running under RSTS/E V8.0. | 


Performance 


RSTS V9.0 generally useS more processing overhead than previous 


versions, due to the many new features added to the monitor. Most 
light- to medium-loaded systems will not notice this extra overhead, 
while heavily loaded systems may see some performance loss. Your 


system's performance will depend on your type of processor, amount of 
memory, type and organization of disks, and the number and types of 
jobs running on your system. 


Performance in some areas of the system is better. For example, the 
new BACKUP package allows you to backup your disks faster than before. 
Also, the new virtual disk feature allows systems with sufficient 
memory to reduce disk accesses by keeping frequently used or heavily 
overlaid programs on the virtual disk in memory. 
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DIGITAL is currently investigating other ways to improve system 
performance on RSTS in the future. 


Compatibility with RSTS/E Version 8.0-7 


RSTS/E Version 9.0 is generally upwards compatible from Version 8.0-7 
at the program level. Features which could affect this compatibility, 
such as multiple privileges and quotas, can be installed in ae way 
which is compatible with their Version 8.0 implementation. A complete 
description of these differences can be found in the RSTS/E Version 
9.0 Release Notes. 


Quality Evaluation 


RSTS/E Version 9.0 has received the highest level of quality testing 
of any RSTS system ever. An extenSive package of regression tests and 
installation tests has been performed on all of the development base 
levels for the product. Field testing has been performed for eight 
months at over 30 sites, with a consensus among the sites that they 
would recommend running V9.0. 


ORDERING/AVAILABILITY INFORMATION 
RSTS/E Version 9.0 is scheduled to be available in June, 1985. For 


specific service availability and pricing information, please contact 
your local DIGITAL Account Manager. 
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USING SAVE/RESTORE ON A TWO-DISK SYSTEM 


This article describes the procedure for using SAVE/RESTORE to backup 
the disks on a system which has only two disk drives and no magnetic 
tape drives. On such a system, you can backup the system disk by 
shutting down the RSTS/E system and using the SAVRES option of INIT. 
It 1S impossible, however, to perform such a backup of the non-system 
disk, since the procedure would require that the system disk, the disk 
being backed up, and the SAVE volume all be mounted simultaneously, 
and hence would require three or more disk drives, or a magnetic tape 
drive. 


The solution presented in this article is to place a copy of the 
INIT.SYS system initialization code on the non-system disk, allowing 
it to run as the "system" disk for off-line SAVE/RESTORE operations. 
This procedure has one drawback: the INIT.SYS initialization code 
requires about 600 blocks on the non-system disk (about 11% of an 
RKOS). If you have small disks, such as RKO5's or RLO1's, you should 
consider expanding your hardware to include another disk drive or 
magnetic tape unit. For disks larger than RLO1's, the overhead of 
having the INIT.SYS initialization code on each non-system disk is 
usually small enough to be tolerable, although you must decide based 
on your system's needs. 


You should put the INIT.SYS initialization code ([0,1]INIT.SYS) on the 
non-system disk immediately after initializing the disk with DSKINT. 
This ensures that there is enough space for INIT.SYS. After 
generating the monitor, run-time system, and system library, perform 
the procedures outlined below. In the following example, the notation 
"SYO0:" denotes the disk drive on which your normal system disk is 
mounted, and "xxn:" denotes the other disk drive, which is used _ for 
various purposes in the procedure: 


l. If you have not yet initialized the non-system disk that you plan 
to use, initialize it using the DCL INITIALIZE command or _ the 
DSKINT utility. Then mount the disk using the MOUNT command. 


2. Issue the commands given below: 


$ COPY [0,l1]INIT.SYS xxn:[0,1]/CLUSTER SIZE=16 
S$ RUN SYSGENS:HOOK.SAV<cr> 

<HOOK's header line> 

*xxn:[0,1L]INIT.SYS<cr> 

Hook complete 

EAZ 


$ 
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3 


Your non-system disk is now ready to use. 
mount it as a public or private disk if you desire. 
to back 


Seq 0.2.1 N 


You may dismount it and 
When you wish 
up that disk, you must shut down your system, bootstrap 


the non-system disk, and mount a scratch disk in place of your 


normal 
SAVE or 


system disk. You may now use the SAVRES option of INIT to 
IMAGE-copy your non-system disk to the backup disk. 


NOTE 


Every time you install an update, you must delete 
the copies of INIT.SYS on any other disks to which 
you have copied it, and repeat the above 
procedure. 
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DEVICES WITH NON-STANDARD UNIBUS ADDRESSES AND VECTORS 


Some installations have devices which are installed at non-standard 
UNIBUS addresses or which vector to non-standard locations. INIT does 
not automatically recognize these devices. Of course, the best 
solution is to have field service reconfigure these devices so that 
they conform to the standard. Appendix C of the RSTS/E System 
Installation and Update Manual contains the information you need to 
determine the correct UNIBUS addresses and vectors for all devices 
Supported by RSTS/E. Note that extra units such as the second RX, 
second PR, etc., do not have "homes" and must use the CSR option. 


If re-configuration is not possible, you can use the HARDWR option of 
INIT. The CSR  suboption sets non-standard UNIBUS addresses and the 
VECTOR suboption sets non-standard vectors. DIGITAL strongly 
recommends that you use only the CSR suboption. This tells INIT to 
find the device at its non-standard UNIBUS address, but lets INIT 
determine the device's vector. If the device is functioning properly, 
INIT will find the device's non-standard vector. The only device for 
which INIT cannot determine a vector is the card reader. If a card 
reader has a non-standard vector, you must use the VECTOR’ suboption. 
The PA611 paper tape reader must be powered on for INIT to find its 
vector. Use the VECTOR suboption if you intend to start your system 
with a PA61l paper tape reader powered off. 


Be careful when you assign non-standard vectors to devices. INIT 
checks all device vectors (assigned through the VECTOR suboption or 
automatically determined) against a table of reserved locations. INIT 
also checks to see if any vector location is used by more than one 
device. Any conflict will print the message: 


Vector for Device XXn: (vvv) already in use - device disabled 


where vvv is the octal address of the erring vector. 
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The RSTS/E reserved locations, which may not be used as device 
vectors, are: 


Addresses RSTS/E usage 
0-2 Detection of jumps to 0 and traps to 0 
4-36 System trap vectors 
40-56 Reload start addresses, failure HALT 
100-102 KW11-L line frequency clock vector 
104-106 KW11-P crystal clock vector 
110-112 Jump to 0 handling 
114-116 Memory parity trap vector 
144-146 Crash dump handling 
234-236 Statistics handling 
240-242 PIRQ trap vector 
244-246 FPP or FIS exception trap vector 


2502252 Memory Management Unit trap vector 
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DISABLING THE USE OF DATA SPACE - MONITOR FEATURE PATCH 


PROBLEM: 


Some systems may find it desirable to permanently disable the use of 
data space by the monitor because optional software generated into the 
system 1S not compatible with the monitor using data space. If your 
monitor contains any unsupported software, such as a locally written 
device driver, then it is unlikely to work with data space. The only 
Supported monitor software which works with data space is software 
that comes from either the RSTS/E V9.0, DECnet/E V2.1, FMS-11 V1.5, 
RSTS/E 3271 Protocol Emulator, or RSTS/E High Performance 2780/3780 
Protocol Emulator distribution kits. Note that data space will 
automatically not be used if your system includes’ the optional 
RSTS/E-2780 (RJ2780) package. 


SOLUTION: 


The patching procedure detailed as follows will cause the monitor. to 
never use data space, regardless of whether the processor it is 
running on supports it or not. 


Note 


This patch does not disable user-mode instruction and 
data space. Non-standard monitor code may need 
modification before attempting to run any user. programs 
which use separate instruction and data space. 


PROCEDURE: 


1. This is a feature patch to the RSTS/E V9.0 monitor. It may be 
installed in any target monitor SIL. 


2. The patch described in Step 4 can be installed using the PATCH 
option of INIT.SYS: 


Option: PATCH 
File to patch? <cr> (RETURN for installed monitor SIL) 


3. This patch can be installed manually using ONLPAT, the on-line 
patching program. Note, however, that if the patch is applied 
online to the installed monitor SIL, it will not take effect until 
the system is re-booted. 
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RUN SONLPAT 

Command File Name? <cr> 
File to patch? <cr> 

File found in account [0,1] 
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(RETURN for manual installation) 


(RETURN for 


installed monitor SIL) 


This feature patch is contained in the file PA0301.001 as part of 
the UPDATE package. To transfer this file to the UPDATES account, 
select the package name UPDATE during the system installation or 


update procedure. 
4, The patch is as follows: 
Module name? DEFALT 


Base address? ..NODS 
Offset address? 0 


Base Offset Old New? 
001000 000000 000000 ? \ 
001000 000000 000 ? -l 
001000 000001 000 ? *Z 


Offset address? “*Z 
Base address? %*Z 
Module name? RSTS 
Base address? $S$0301 
Offset address? 0 
Base Offset Old New? 
2222??? QOO0000 ?77?77? +? QO!1 
222227? 000002 227A??? i emis, Gh 


Cr ce ae i A 


(CTRL/Z for 
(CTRL/Z for 
(CTRL/Z for 


(up-arrow/C 
for INIT) 


new offset) 
new base) 
new module) 


to exit; CTRL/C 
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CHANGING SPECIAL LOGIN TERMINAL - TERMINAL SERVICE FEATURE PATCH 


The number of jobs that can log in to a RSTS/E system is limited by 
the swapping space available, the JOB MAX set at system start-up time, 
and the login setting (set by the SET SYSTEM/[NO]LOGINS command). 
However, the console terminal (KBO:) is a special terminal, and can 
log in regardless of the login setting, provided that swapping space 
and JOB MAX permit. 


With the following patch, one or two special keyboards can be 
selected, or this feature can be disabled entirely. 


PROCEDURE: 


1. This is a feature patch to the RSTS/E V9.0 monitor. It may be 
installed in any target monitor SIL. 


2. Decide which terminals should be allowed to log in regardless of 
the login setting, and use those numbers as m and n in the patch 
in step 5. If you want to allow only one terminal, use its number 
as m and use -1l in place of n. If you want to disable this 
feature, use -l in place of both m and n. Be Sure you include the 
decimal point after the new value of m or nso that it is 
interpreted as a decimal number. 


3. The patch described in Step 5 can be installed using the PATCH 
option of INIT.SYS: 


Option: PATCH 
File to patch? <cr> (RETURN for installed monitor SIL) 


4, This patch can be installed manually using ONLPAT, the on-line 
patching program: 


RUN SONLPAT 

Command File Name? <cr> (RETURN for manual installation) 
File to patch? <cr> (RETURN for installed monitor SIL) 
File found in account [0,1] 


This feature patch is contained in the file PA0303.001 as part of 
the UPDATE package. To transfer this file to the UPDATES account, 
select the package name UPDATE during the system installation or 
update procedure. | 
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NOTE 


The patch file for this patch requires manual 
editing to include installation specific parameters 
before it can be successfully installed. 


5. The patch is as follows: 
Module name? TER 


Base address? ..CTZ. 
Offset address? 0 


Base Offset Old New? 

2??2???? OO00000 000000 ?m.*2 (or -1, from step 2) 
2?2????? #O00002 001407 ? *Z (CTRL/Z for new offset) 
Offset address? %*Z (CTRL/Z for new base) 


Base address? ..CTY. 
Offset address? 0 


Base Offset Old New? 

2???2?? +O00000 177777 #?n.*2 (or -1, from step 2) 
2??2???? #000002 001404 ? *Z (CTRL/Z for new offset) 
Offset address? *Z (CTRL/Z for new base) 
Base address? %Z (CTRL/Z for new module) 


Module name? RSTS 
Base address? $$0303 
Offset address? 0 


Base Offset Old New? 
22222? QOO000 ?7?7?7??? ? Q!i 
22°72? OO00002 277222" <2 AE (up-arrow/C to exit; CTRL/C 


for INIT) 
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INPUT ESCAPE SEQUENCE HANDLING - TERMINAL SERVICE FEATURE PATCH 


RSTS/E allows multiple character incoming escape sequences. The 


RSTS/E Programming Manual fully describes the escape sequence 
handling. 


One of the multi-character escape sequences is ESCape followed by "P", 
followed by one modifier character. On the VT52 terminal, the upper 
left-hand key on the auxiliary keypad (usually blue) generates ESC P. 
When the VT100 terminal is operating in VT52 mode, the upper left-hand 
key on the auxiliary keypad (usually labeled "PF1") generates ESC P. 
If the terminal user types this key and then any other graphic key, 
the whole sequence is gathered by the terminal service and delivered 
to the application program. None of the sequence is echoed. Thus, 
the blue key can be considered a "function" key to be followed by some 
function code character. 


On the other hand, some existing applications using the VT52 may 
expect this key to generate a stand-alone escape sequence with no 
required (or desired) modifier character. You may install the 
following patch to change the terminal service so that the ESCape, "P" 
sequence does not expect a modifier character. Note that this patch 
affects all terminals on the system. 


PROCEDURE: 


1. This is a feature patch to the RSTS/E monitor. It may be 
installed in any target monitor SIL. 


2. The patch described in Step 4 can be installed using the PATCH 
option of INIT.SYS: 


Option: PATCH 
File to patch? <cr> (RETURN for installed monitor SIL) 


3. This patch can be installed manually using ONLPAT, the on-line 
patching program: 


RUN SONLPAT 

Command File Name? <cr> (RETURN for manual installation) 
File to patch? <cr> (RETURN for installed monitor SIL) 
File found in account [0,1] 


This feature patch is contained in the file PA0303.002 as part of 
the UPDATE package. To transfer this file to the UPDATES account, 
select the package name UPDATE during the system installation or 
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update procedure. 
4, The patch is as follows: 


Module name? TER 
Base address? ..ESCP 
Offset address? 0 
Base Offset Old New? 
222??? +.OOO000O0 O50001 ? Q&177400 
2222??? QOO0002 ?27772?? #%? *Z (CTRL/Z for 
Offset address? “Z (CTRL/Z for 
Base address? “*Z (CTRL/Z for 
Module name? RSTS 
Base address? $S$0303 
Offset address? 0 
Base Offset Old New? 
22222? QOO0000 ?777?? =? Q!2 
2222??? QOOO0O02 27777? #? *C (up-arrow/C 
for INIT) 
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new offset) 
new base) 
new module) 


to exit; CTRL/C 
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UNDERSTANDING TERMINAL PARITY AND STOP BIT SETTINGS 


Terminal Parity 


The DCL command SET TERMINAL/[NO]PARITY[=ODD!EVEN] controls the format 
in which data characters are sent to aterminal. /NOPARITY (the 
default) sends the full 8 bits of a byte out to a terminal. If the 
/NOEIGHTBIT characteristic is set, /PARITY=EVEN and /PARITY=ODD trim 
the byte to 7 bits of data and then set or clear the eighth bit to 
achieve the correct parity setting. (Note: Binary Output Mode is 
"Data Binary Output Mode". /NOPARITY yields 8 bit data, /PARITY=EVEN 
and /PARITY=ODD yield 7 bit data if the /NOEIGHTBIT characteristic is 
set.) 


The DL11A/B/C/D/E and DJ1ll interfaces do not have programmable 
hardware parity generation. For these interfaces, terminal service 
generates the output parity bit. The DH11, DHV11, DHU11 and DZ1l have 
programmable hardware parity generation, which is used by terminal 
service. 


Stop Bit Settings 


Terminal interfaces with programmable baud rate settings (DH11l, DHV11, 
DHU11 and DZ1l) also have programmable stop-bit settings. RSTS will 
automatically select 2 stop bits for speed settings of 110 baud or 
less and 1 stop bit for speeds greater than 110 baud. Older 
mechanical terminals, such as the ASR33 (which runs at 110 baud), 
require the time delay of 2 stop bits for synchronization. Modern 
terminals need only 1 stop bit. 


When converting from baud rates to characters per second (CPS), the 
correct number of stop bits becomes clear. Asynchronous communication 
consists of 1 start bit, 8 data bits, and 1 or 2 stop bit(s). 


(110 BITS PER SECOND) 


ete ne ce emt cet ee a nee eee ee eee ee ee ee cee ee ee 


(1+8+2 BITS PER CHARACTER) 


It 
— 
bh 
Oo 
™~ 
_ 
~ 

i 


10 CHARACTERS PER SECOND 


(300 BITS PER SECOND) 


(1+8+1 BITS PER CHARACTER) 


30 CHARACTERS PER SECOND 


VW 
Go 
© 
© 
™~ 
on 
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li 
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MODEM CONTROL ON PRIVATE, LEASED LINES 


Some RSTS/E installations use private, leased phone lines for terminal 
connections. If the line has no modem or no modem control (for 
example, data signals only) then the line should be set as a local 
line using the DCL command SET TERMINAL/NODIALUP. In this case the 
private, leased line is simply a long local connection. On the other 
hand, many private, leased lines do use modem control. 


When using modem control, there are five modem signals used by RSTS/E: 

1. Ring Indicator (Circuit CE, pin 22) 
This signal is true if the modem's "phone" is ringing. RSTS/E 
does not control this signal; the modem does. Private, leased 
lines normally do not "ring." 

2. Carrier Detect (Circuit CF, pin 8) 
This signal is true when the modem is receiving carrier from 
the modem on the other end of the line. RSTS/E does not 
control this signal; the modem does. 


3. Clear to Send (Circuit CB, pin 5) 


This signal is true when it is "OK to send data" to the other 
modem. RSTS/E does not control this signal; the modem does. 


4. Data Terminal Ready (Circuit CD, pin 20) 


This signal is controlled by RSTS/E, not the modem. When 
RSTS/E sets this Signal to true, the modem answers the phone 
(if it is not already answered) and sends carrier to the modem 
at the other end of the connection. 


5. Request to Send (Circuit CA, pin 4) 
This signal is controlled by RSTS/E, not the modem. When 
RSTS/E sets this signal to true, the modem tells the other 


modem it is now "clear to send". 


RSTS/E always sets and clears Data Terminal Ready and Request to Send 
together. 
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The normal sequence for a dial-up modem line is: 


1. Someone calls in. The modem asserts Ring Indicator. 


2. RSTS/E sets Data Terminal Ready and Request to Send. 


3. The 


modem answers the phone and sends out carrier and Clear to 


Send. The Ring Indicator goes off. 


4. The 


other end sends carrier and Request to Send. The modem 


sets Carrier Detect and Clear to Send. 


5. RSTS/E enables the line for data communication. 


6. Data communication occurs... 


7. #=‘The 
and 


other end drops carrier. The modem clears Carrier Detect 
Clear to Send. 


8. RSTS/E starts a 5 second timeout. 


9. The 


timeout expires. RSTS/E clears Data Terminal Ready and 


Request to Send. 


10. The connection is now broken. 
In addition, RSTS/E polls all modem lines once each_ second. if 
Carrier Detect has come on without a Ring Indication, the line will be 


enabled 
Carrier 
happens 
line as 


by setting Data Terminal Ready and Request to. Send. If 

Detect iS on when the system is initially started, this 
immediately. So, to use a modem-controlled private, leased 
a local line: 


1. Strap the Ring Indicator signal false. This ensures that 
RSTS/E never sees a "ringing" line to get confused about. 


2. Strap the Carrier Detect and Clear to Send signals true. This 
ensures that RSTS/E will immediately enable the line by 
setting Data Terminal Ready and Request to Send. 
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CONTROLLING EMT LOGGING - FILE PROCESSOR FEATURE PATCH 


If you included EMT Logging when you generated your system, you may 
want to modify the set of directives which the monitor passes to your 
logging program. The following procedure allows you to enable or 
Gisable EMT logging for each of the directives which can be logged. 


PROCEDURE: 


1. This is a feature patch to the RSTS/E V9.0 monitor. It may be 
installed in any target monitor SIL which has been generated to 
include the EMT Logging feature. If you attempt to install this 
patch ona SIL that does not include the EMT logging feature, the 
patch will fail with the error, "?Address above module bounds." 


2. Note that as supplied, the patch disables logging for each of the 
directives. DIGITAL recommends that you retain a copy of the 
patch in this form, to use as a Starting point for creating later 
versions, should your requirements change. 


3. Decide which directives you want to have logged. For each one, 
locate the appropriate segment(s) of the patch. The value under 
"New?" will be "Q!100", which is the value to disable logging. To 
enable logging (reversing the sense of the patch), replace this 
value with "Q&\100". 


4, Note that some directives can be invoked via CALFIP, some via 
.UUO, and some via either CALFIP or .UUO. The following patch 
contains three sections: the first controls those directives 
which can be invoked via either CALFIP or .UUO. (The second and 
third control those directives invoked via CALFIP alone and  .UUO 
alone, respectively.) You will need to make TWO changes for any 
directive appearing in the first group: once for the CALFIP 
invocation path, and once for the .UUO invocation path. 


The paired directives appear next to each other in the first 
group. Directives appear in ascending order by CALFIP code _ for 
the first two groups, and by .UUO code for the third group; these 
codes are the MACRO values documented in the RSTS/E_ System 
Directives Manual. 
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5. The patch described in Step 7 can be installed using the PATCH 


option of INIT.SYS: 


Option: PATCH 
File to patch? <cr> 


(RETURN for installed monitor SIL) 


6. This patch can be installed manually using ONLPAT, the on-line 
patching program. Note, however, that if the patch is applied 
online to the installed monitor SIL, it will not take effect until 


the system 1s re-booted. 


RUN SONLPAT 


Command File Name? <cr> 


File to patch? <cr> 


(RETURN for manual installation) 
(RETURN for installed monitor SIL) 


File found in account [0,1] 


This feature patch is contained in the file PA0305.001 as part of 
the UPDATE package. To transfer this file to the UPDATES account, 
select the package name UPDATE during the system installation or 


update procedure. 


The patch file 


NOTE 


for this patch requires manual 


editing to include installation specific parameters 
before it can be successfully installed. 


7. The patch is as follows: 


Module name? RSTS 
Base address? EMLTBL 
Offset address? 0 


Base Offset Old 
2??P2P7?? 000000 PPP??? 


eo e© @ @ @ © NNN NN Nt le 


Offset address? “*Z 
Base address? $$0305 
Offset address? 0 


Base Offset Old 
222??? QOO0001L ?7???? 
22222? 000002 22a 


Offset address? “*Z 

Base address? SEMLFQ 
functions 

Offset address? ASSFQ/2 


Base Offset Old 
222??? 000012 2777??? 
222??? 000014 ?????? 


Offset address? “*Z 


: Verify EMT Logging generated 


New? 

2 FZ, (CTRL/Z for new offset) 
(CTRL/Z for new base) 

New? 

? QOt1 

2 27 (CTRL/Z for new offset) 


(CTRL/Z for new base) | 
; Beginning of paired CALFIP - UUO 


+ ASSIGN function, CALFIP flavor 
New? 
2? QO!100 
? AZ (CTRL/Z for new offset) 
(CTRL/Z for new base) 
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Base address? SUUOSN 
Offset address? UU.ASS-UUSMIN 


Base Offset Old New? 
TPP e 2? 000047 2??? 8? Q!100 
222??? 000050 222° 287, 
Offset address? %*Z 
Base address? SEMLFQ 
Offset address? DEAFQ/2 
flavor 

Base Offset Old New? 
22?2???? 000013 2??? ? Q!100 
22222? 000014 22. (2 DZ 


Offset address? %*Z 
Base address? SUUOSN 
Offset address? UU.DEA-UUSMIN 


Base Offset Old New? 
222??? 000050 ??7?77?? =? Q!100 
222??? 000052 ?777?? ? *Z 
Offset address? %*Z 
Base address? SEMLFQ 
Offset address? DALFQ/2 
flavor 

Base Offset Old New? 
2222??? 000014 2277??? =? 9Q!100 
2277??? 000016 ??777?? ? *Z 


Offset address? “*Z 

Base address? SUUOSN 

Offset address? UU.DAL-UUSMIN 
flavor 


Base Offset Old New? 
222??? 000051 2??? ©? Q!100 
222??? 000052 P22. 2 OZ 
Offset address? %*Z 
Base address? SEMLFQ 
Offset address? LOKFQ/2 

Base Offset Old New? 
222??? 000011 2??? ? QO!100 
e222 e? 000012 C227 27 


Offset address? “*Z 
Base address? SUUOSN 
Offset address? UU.LOK-UUSMIN 


Seq 3.5.1 F 
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s ASSIGN function, UUO flavor 
(CTRL/Z for new offset) 
(CTRL/Z for new base) 


; DEASSIGN function, CALFIP 


(CTRL/Z for new offset) 
(CTRL/Z for new base) 


; DEASSIGN function, UUO flavor 
(CTRL/Z for new offset) 
(CTRL/Z for new base) 


: DEASSIGN ALL function, CALFIP 


(CTRL/Z for new offset) 
(CTRL/Z for new base) 


: DEASSIGN ALL function, UUO 


(CTRL/Z for new offset) 
(CTRL/Z for new base) 


> LOOKUP function, CALFIP flavor 
(CTRL/Z for new.offset) 
(CTRL/Z for new base) 


; LOOKUP function, UUO flavor 


Base Offset Old New? 

Creer? 000056 ?7?7?7??? ? Q!100 

eer 2e? 000060 7777??? ? *Z (CTRL/Z for new offset) 
Offset address? “*Z ; End of paired CALFIP - UUO functions 
Base address? SEMLFQ ; Beginning of CALFIP-only functions 


Offset address? CLSFQ/2 


Base Offset Old New? 


* CLOSE function 
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(CTRL/Z for new offset) 
> OPEN function 


(CTRL/Z for new offset) 
* CREATE function 


(CTRL/Z for new offset) 
: DELETE function 


(CTRL/Z for new offset) 
» RENAME function 


(CTRL/Z for new offset) 
» DIRECTORY (wildcard) function 


(CTRL/Z for new offset) 
* RESET function 


(CTRL/Z for new offset) 
; CREATE Temporary file function 


(CTRL/Z for new offset) 
; CREATE Binary file function 


(CTRL/Z for new offset) 
s RUN function 


(CTRL/Z for new offset) 


; End of CALFIP-only functions 
; Beginning of UUO-only functions 


RSTS/E V9.0 
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22????? 000000 ?7?7?7?? ? 9Q!:100 
2222??? 000002 ?777?7? ? *Z 
Offset address? OPNFQ/2 

Base Offset Old New? 
al ata at ald 000001 2??? ? Q!100 
2222??? 000002 eae | SOON”, 
Offset address? CREFQ/2 

Base Offset Old New? 
eeeee? 000002 ?777?7?? ? Q!100 
C22 622 000004 7777??? ? *Z 
Offset address? DLNFQ/2. 

Base Offset Old New? 
22222? 000003 2??? ? Q!f100 
22222? 000004 208 SPO 
Offset address? RENFQ/2 

Base Offset Old New? 
222??? 000004 ?72777? ? Qg!:100 
222222 000006 ?777?7? ? %*Z 
Offset address? DIRFQ/2 

Base Offset Old New? 
2222?2 000005 229) 2° °-OL1.00 
P2272? 000006 B22 BF, 
Offset address? RSTFQ/2 

Base Offset Old New? 
Leh ee 3 000010 . ??7???? ? Q!:100 
2222??? 000012 ?7277?7?? ? *Z 
Offset address? CRTFQ/2 

Base Offset Old New? 
22222? 000015 2??? ? Q!100 
222729? 000016 222.2 SZ 
Offset address? CRBFQ/2 

Base Offset Old New? 
2222??? 000016 2727??? =? 9g!100 
22222? 000020 ?777?7?? ? %*Z 
Offset address? RUNFQ/2 

Base Offset Old New? 

Ce ee a 000017 2??? ©? Q!100 
2?2????? 000020 22f RZ 
Offset address? “Z 

Base address? SUUOSN 

Offset address? UU.TB3-UUSMIN 

Base Offset Old New? 
22722? 000000 ?7???? ? Q!100 
CLEC 27 000002 ?777?7?? ? *Z 
Offset address? UU.SPL-UUSMIN 

Base Offset Old New? 

22 e222 000001 2??? ? Q!100 
eer ee? 000002 2! 2, ae 


+ Monitor Tables III function 


(CTRL/Z for new offset) 
* SPOOL function 


(CTRL/Z for new offset) 
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Offset address? UU.DMP-UUSMIN 


Base Offset Old New? 
222??? 000002 ?7?77?? =? Q!100 
222??? 000004 ?77277?7?? ? *Z 
Offset address? UU.FIL-UUSMIN 

Base Offset Old New? 
2222??? 000003 2??? ? Q!100 
22222? 000004 2??? ? *Z 
Offset address? UU.ATR-UUSMIN 

Base Offset Old New? 
222??? 000004 ?7?7?7?? ? Q!100 
222??? 000006 ??77?7?7?? ? *Z 
Offset address? UU.LOG-UUSMIN 

Base Offsr*+ Old New? 
2222??? 0000.2 ?77?7?? +? Q!100 
222??? 000014 272777? ? *Z 
Offset address? UU.RTS-UUSMIN 

Base Offset Old New? 
22?2??7?? 000013 2??? ? Q!100 
2222?? 000014 P28 OZ, 
Offset address? UU.NAM-UUSMIN 

Base Offset Old New? 
222??? 000014 2777??? =? Q!100 
222??? 000016 2772777? ? *Z 
Offset address? UU.ACT-UUSMIN 

Base Offset Old New? 
222??? 000016 ??7?7?7?? ? Q!100 
222??? 000020 277777? ? *Z 
Offset address? UU.DAT-UUSMIN 

Base Offset Old New? 
22?22?? 000017 2??? ? Q!100 
222?2?? 000020 222 OF OZ 
Offset address? UU.PRI-UUSMIN 
function 

Base Offset Old New? 
2222??? 000020 ?7?7?7?? ? Q!100 
222??? 000022 772777? ? *Z 
Offset address? UU.TB2-UUSMIN . 

Base Offset Old New? 
222??? 000021 2??? 8? Q!100 
222??? 000022 222 BAZ 
Offset address? UU.BCK-UUSMIN 
function 

Base Offset Old New? 
222??? 000022 ?777?7?? =? Q!100 
222??? 000024 ?77?7?? ? *Z 


Offset address? UU.HNG-UUSMIN 


Base 


Offset 


Old New? 
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; Snapshot dump function 


(CTRL/Z for new offset) 
* FILe statistics function 


(CTRL/Z for new offset) 
s Read/Write attributes function 


(CTRL/Z for new offset) 
; Set number of logins function 


(CTRL/Z for new offset) 
* RTS/RESLIB control functions 


(CTRL/Z for new offset) 
s RTS name for file function 


(CTRL/Z for new offset) 
; Accounting dump function 


(CTRL/Z for new offset) 
; System date/time function 


(CTRL/Z for new offset) 
; Priority/Run Burst/Size 


(CTRL/Z for new offset) 
* Monitor Tables II function 


(CTRL/Z for new offset) 
; File backup statistics 


(CTRL/Z for new offset) 
; Hangup dataset function 
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2??22??? 000026 7777??? ? *Z (CTRL/Z for new offset) 
Offset address? UU.FCB-UUSMIN > FCB/WCB/DDB data function 
Base Offset Old New? 
al ara ara 000025 2??? ? Q!100 
2222??? 000026 22? (2° Z (CTRL/Z for new offset) 
Offset address? UU.POK-UUSMIN * POKE function 
Base Offset Old New? 
Ce2eee 000027 2??? 2? Q!100 
2222??? 000030 222 72 AZ (CTRL/Z for new offset) 
Offset address? UU.TB1-UUSMIN s Monitor Tables I function 
Base Offset Old New? 
Catone ge ate 000032 2777??? =? Q!100 
2222??? 000034 ?2272272?? ? *Z (CTRL/Z for new offset) 
Offset address? UU.NLG-UUSMIN ; Disable further logins 
function 
Base Offset Old New? 
2222? 000033 2??? 2? Q!100 
222??? 000034 2??? ? *Z (CTRL/Z for new offset) 
Offset address? UU.YLG-UUSMIN ; Enable logins function 
Base Offset Old New? 
oe ee? ? 000034 ?77?7?? =? 9g!100 
222??? 000036 22777??? ? *Z (CTRL/Z for new offset) 
Offset address? UU.PAS-UUSMIN * Create PPN function 
Base Offset Old New? 
227??? 000035 22? ? Q!100 
2222??? 000036 229° QO AZ, (CTRL/Z for new offset) 
Offset address? UU.DLU-UUSMIN * Delete PPN function 
Base Offset Old New? 
Ce 2 ee? 000036 2727277? =? Q!100 
222272? 000040 ?7?77?? ? *Z (CTRL/Z for new offset) 
Offset address? UU.MNT-UUSMIN : Disk/Terminal functions 
Base Offset Old New? 
Pe at ae ara 4 000040 ??7?7?7??? =? 9g!100 
2222??? 000042 227272??? ? *Z (CTRL/Z for new offset) 
Offset address? UU.LIN-UUSMIN + LOGIN function 
Base Offset Old New? 
P2772 2 000041 2??? ? Q!100 
222702 000042 Pee. <2 AZ (CTRL/Z for new offset) 
Offset address? UU.BYE-UUSMIN s LOGOUT function 
Base Offset Old New? 
2227??? 000042 22727??? =? Q!100 
2222?? 000044 ?22727?? ? *Z (CTRL/Z for new offset) 
Offset address? UU.ATT-UUSMIN s ATTACH function 
Base Offset Old New? 
22272? 000043 222 2° 01700 
2222?? 000044 22? 2 AZ, (CTRL/Z for new offset) 


Offset address? UU.DET-UUSMIN + DETACH function 
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Base Offset 
2222??? 000044 
2222??? 000046 
Offset address? UU. 

Base Offset 
2222??? 000046 
22272?? 000050 
Offset address? UU. 

Base Offset 
222727?? 000052 
e222? 000054 
Offset address? UU. 
function 

Base Offset 
222??? 000053 
2272??? 000054 
Offset address? UU. 

Base Offset 
222222 000054 
22722 2 000056 
Offset address? UU. 
function 

Base Offset 
2222??? 000055 
22222? 000056 
Offset address? UU. 

Base Offset 
22222? 000060 
2222??? 000062 
Offset address? UU. 

Base Offset 
2222??? 000061 
222??? 000062 
Offset address? UU. 

Base Offset 
222??? 000064 
2222??? 000066 
Offset address? UU. 

Base Offset 
222222 000065 
2222??? 000066 
Offset address? UU. 

Base Offset 
222??? 000066 
222??? 000070 
Offset address? UU. 

Base Offset 
2222??? 000067 


Old New? 
2222??? ? Q!100 
P2222? «eZ, 
ERR-UUSMIN 
Old New? 
22222? ? Q!100 
eee ce a NZ, 
ZER-UUSMIN 
Old New? 
2222??? ? Q!100 
CeCe ee: 2 eZ 
RAD-UUSMIN 
Old New? 
22? 2? Q!100 
P22. 2 SZ 
DIR-UUSMIN 
Old New? 
2?2?2?2??? «2? Q!100 
Leer? Pe AZ 
TRM-UUSMIN 
Old New? 
22? +? Q!100 
22? 2 AZ 
CHE-UUSMIN 
Old New? 
Car ar oat ate ? 9!100 
Bee eee, -F ee 
CNV-UUSMIN 
Old New? 
2??? ? Q!100 
Pee ea, 
SWP-UUSMIN 
Old New? 
22222? —2:-O1100 
OOOO. a INT, 
JOB-UUSMIN 
Old New? 
2??? ? Q!100 
eer (ef OZ 
PPN-UUSMIN 
Old New? 
22???? ? OF100 
SOLER? 2 AZ 
SYS-UUSMIN 
Old New? 
2??? #=©? Q!100 


Seq 3.5.1 F 


7 of 8 


(CTRL/Z for new offset) 
; Error message text function 


(CTRL/Z for new offset) 
> ZERO device/PPN function 


(CTRL/Z for new offset) 
; Read/Write accounting data 


(CTRL/Z for new offset) 
; Directory (index) function 


(CTRL/Z for new offset) 
* Terminal characteristics 


(CTRL/Z for new offset) 
; Disk caching control function 


(CTRL/Z for new offset) 
* Date/Time conversion function 


(CTRL/Z for new offset) 
: System file control function 


(CTRL/Z for new offset) 
* Job creation function 


(CTRL/Z for new offset) 
; PPN wildcard lookup function 


(CTRL/Z for new offset) 
* Job status function 
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222??? 000070 220. (2°02 (CTRL/Z for new offset) 
Offset address? UU.STL-UUSMIN ; Stall system function 

Base Offset Old New? 

Cee eee 000072 272772??? =? Q!100 

2222??? 000074 ??777?? ? *Z (CTRL/Z for new offset) 
Offset address? UU.ONX-UUSMIN : Open next function 

Base Offset Old New? 

eee ere 000076 ?72?7?7?7? =? Q!100 

222208 000100 ~—???2?7?? 2? AC (up-arrow/C to exit; CTRL/C 


for INIT) 
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USING THE CSS PAPER TAPE READER ON RSTS/E- DEVICE DRIVER FEATURE PATCH 


PROBLEM: 


The paper tape reader device driver included in the RSTS/E object 
library does not work with the CSS paper tape reader (PA611). 


SOLUTION: 


The paper tape reader driver for RSTS/E is for Digital Equipment 
Corporation model PCl1l. The following optional patch will make the 
driver compatible with the CSS paper tape reader model PA611. Note 
that after applying this patch, the device driver does not work with 
model PCll. 


PROCEDURE: 


1. This is a feature patch to the RSTS/E monitor. It may be 
installed in any target monitor SIL that supports paper tape 
readers. If this support was not included in the monitor during 
your system generation, the patch will fail with a "Symbol not 
found in STB" error after you specify ..PCSS as the Base Address. 


2. The patch described in Step 4 below can be installed using the 
PATCH option of INIT.SYS: 


Option: PATCH 
File to patch? <cr> (RETURN for installed monitor SIL) 


3. This patch can be installed manually using ONLPAT, the on-line 
patching program: 


RUN SONLPAT 

Command File Name? <cr> (RETURN for manual installation) 
File to patch? <cr> (RETURN for installed monitor SIL) 
File found in account [0,1] 


This feature patch is contained in the file PA0307.001 as part of 
the UPDATE package. To transfer this file to the UPDATES account, 
select the package name UPDATE during the system installation or 
update procedure. | | 
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4, The patch is as follows: 


Module name? RSTS 
Base address? ..PCSS 
Offset address? 0 


Base Offset Old New? 

222??? #+OOOO00O0 100200 ? 100100 

2?2?2?2?2?? OQO0002 27777??? ? *Z (CTRL/Z for new offset) 
Offset address? %*Z (CTRL/Z for new base) 


Base address? $$0307 
Offset address? 0 


Base Offset Old New? 
22222? QOO00O0 7777??? #? Q!1 
2222??? QOOO002 ?77?7??? ? *C (up-arrow/C to exit; CTRL/C 


for INIT) 
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SPECIAL PRINT-USING CHARACTERS - BASIC-PLUS FEATURE PATCH 


The PRINT-USING option of BASIC-PLUS provides for floating dollar 
Sign, comma insertion every three digits to the left of the decimal 
point, and printing of the decimal point. The S$-sign is used for’ the 
currency symbol in the United States and Canada, but various other 
symbols are used for other monetary systems. In the United Kingdom it 
would be useful to float the Pound Sterling symbol (or whatever ASCII 
character is used to represent that symbol) instead of the $-sign. In 
France, a floating Franc symbol (or F) would be generally more useful 
than the floating $-sign. The role of the comma and period are _ also 
reversed in France (e.g., 9,999,999.02 should be printed as 
9..999.99902).. 


To accommodate these differences in monetary systems, PRINT-USING is 
coded to allow substitution of any character for the floating currency 
symbol, the decimal point character, and the "“every three digits" 
character. These three characters are defined by three words in the 
BASIC-PLUS run-time system. System defaults and several suggestions 
are shown in the table below: 


Location Usage Default England France 
.»PUCH+0 Floating currency symbol S$ (044) & (046) F (106) 
.»PUCH+2 Decimal point character » (056) . (056) , (054) 
.»PUCH+4 Every three digits character , (054) , (054) . (056) 


Substitution of different characters, such as those listed under 
England and France, is done with a simple patch. Any change will 
affect both the PRINT-USING format string and the output produced. 
For example, if the suggestions under’ France were installed, the 
following PRINT-USING statement would result in the output shown: 


PRINT USING "FFH.######,##", 3673298.02, 4545.20 


F3.673.298,02 
F4.545,20 


Since any change in this area does render the PRINT-USING 
documentation slightly incorrect, an appropriate note should be 
published for users of the system. 
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PROCEDURE 3 

1. This is a feature patch to the BASIC-PLUS run-time system. It may 


be installed in any BASIC-PLUS run-time system configured with 
Print-Using. 


Determine the three special characters you want to use for the 
floating currency symbol, the decimal point character, and the 
"every three digits" character. The chosen characters can be 
entered as either: 


"x where x is the chosen printable character 
n where n is the octal value of the chosen character 
n. where n 1s the decimal value of the chosen character 


The patch described in Step 5 can be installed uSing the PATCH 
option of INIT.SYS: 


Option: PATCH 
File to patch? BASIC.RTS (BASIC-PLUS run-time system name) 


This patch can be installed manually uSing ONLPAT, the on-line 
patching program: 


RUN SONLPAT 

Command File Name? <cr> (RETURN for manual installation) 
File to patch? [0,1]BASIC.RTS (BASIC-PLUS run-time system name) 
File found in account [0,1] 


This feature patch is contained in the file PA0401.001 as part of 
the UPDATE package. To transfer this file to the UPDATES account, | 
select the package name UPDATE during the system installation or 

update procedure. 


NOTE 
The patch file for this patch requires manual 


editing to include installation specific parameters 
before it can be successfully installed. 
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5. The patch is as follows: 


Base address? ..PUCH 
Offset address? 0 


Base Offset Old New? 

2????2?? 000000 000044 ? 'f (currency sign from Step 2) 
2????2?? #000002 000056 ? '', (decimal point from Step 2) 
2?2????? 000004 000054 ? '. ("every three" from Step 2) 
2222??? QOO0006 777277? ? *C (up-arrow/C to exit;CTRL/C 


for INIT) 


If the above patch was installed using ONLPAT, it will take effect 
the next time the run-time system is reloaded. If the run-time 
system has been INSTALLED, execute the following commands: 


$ UNLOAD/RUNTIME SYSTEM BASIC (BASIC-PLUS run-time system name) 
NOTE: The UNLOAD command will not remove the run-time system, but 


simply instructs the monitor to reload it the next time a job 
requests it. 
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DEFAULT SCALE FACTOR - BASIC-PLUS FEATURE PATCH 


The BASIC-PLUS default SCALE factor may be modified by utilizing the 
procedure in this article. A complete description of SCALE factors is 


included in the BASIC-PLUS Language Manual. 


PROCEDURE: 


l. 


This is a feature patch to the BASIC-PLUS run-time system. It may 
be installed in any BASIC-PLUS run-time system configured with the 
4-word, scaled math package. 


Determine the new BASIC-PLUS default SCALE factor. This default 
SCALE factor must be between 0 and 6 incluSive. 


The patch described in Step 5 can be installed using the PATCH 
option of INIT.SYS: 


Option: PATCH 
File to patch? BASIC.RTS (BASIC-PLUS run-time system name) 


This patch can be installed manually using ONLPAT, the on-line 
patching program: 


RUN SONLPAT 

Command File Name? <cr> (RETURN for manual installation) 
File to patch? [0,1]BASIC.RTS (BASIC-PLUS run-time system name) 
File found in account [0,1] 


This feature patch is contained in the file PA0401.002 as part of 
the UPDATE package. To transfer this file to the UPDATES account, 
select the package name UPDATE during the system installation or 
update procedure. 


NOTE 
The patch file for this patch requires manual 


editing to include installation specific parameters 
before it can be successfully installed. 
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5. The patch is as follows; 


Base address? ..SCA. 
Offset address? 0 


Base Offset Old New? 
2?2?2?2??? 000000 000000 ?n  °&2~(from Step 2) 
2222??? OO0002 ??777??7 ? *C (up-arrow/C to exit; CTRL/C 


for INIT) 


6. If the above patch was installed using ONLPAT, it will take effect 
the next time the run-time system is reloaded. If the run-time 
system has been INSTALLED, execute the following commands: 


$ UNLOAD/RUNTIME SYSTEM BASIC (BASIC-PLUS run-time system name) 
NOTE: The UNLOAD command will not remove the run-time system, but 


Simply instructs the monitor to reload it the next time a job 
requests it. 
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OMITTING SCALE FACTOR WARNING MESSAGE - BASIC-PLUS FEATURE PATCH 


Normally, if a BASIC-PLUS program is compiled with one SCALE factor 
and then is run under a different job SCALE factor, the "%SCALE Factor 
Interlock" warning message is printed and execution proceeds using the 
program's SCALE factor. It may be desirable to omit the printing of 
this message. 


PROCEDURE: 


l. This is a feature patch to the BASIC-PLUS run-time system. It may 
be installed in any BASIC-PLUS run-time system configured with the 
4-word, scaled math package. 


2. The patch described in Step 4 can be installed using the PATCH 
option of INIT.SYS: 


Option: PATCH 
File to patch? BASIC.RTS (BASIC-PLUS run-time system name) 


3. This patch can be installed manually using ONLPAT, the on-line 
patching program: 


RUN SONLPAT 

‘Command File Name? <cr> (RETURN for manual installation) 
File to patch? [0,1]BASIC.RTS (BASIC-PLUS run-time system name) 
File found in account [0,1] 


This feature patch is contained in the file PA0401.003 as part of 
the UPDATE package. To transfer this file to the UPDATES account, 
select the package name UPDATE during the system installation or 
update procedure. 


4, The patch is as follows: 


Base address? ..SCE. 
Offset address? 0 


Base Offset Old New? . 
22????? OO0000 104577 ? 240 (for no warning message) 
222??? +OO00002 000207 ? *Cc (up-arrow/C to exit; CTRL/C 


for INIT) 
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5. If the above patch was installed using ONLPAT, it will take effect 


the next time the run-time system is reloaded. If the run-time 
system has been INSTALLED, execute the following commands: 


$ UNLOAD/RUNTIME SYSTEM BASIC (BASIC-PLUS run-time system name) 
NOTE: The UNLOAD command will not remove the run-time system, but 


simply instructs the monitor to reload it the next time a job 
requests it. 
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DEFAULT TO NOEXTEND MODE - BASIC-PLUS FEATURE PATCH 


Normally, BASIC-PLUS defaults to EXTEND mode. To change this default 
to NOEXTEND mode, apply the patch in this article. 


PROCEDURE: 

1. This is a feature patch to the BASIC-PLUS run-time system. It may 
be installed in any BASIC-PLUS run-time system. 

2. The patch described in Step 4 can be installed using the PATCH 
option of INIT.SYS: 
Option: PATCH 
File to patch? BASIC.RTS (BASIC-PLUS run-time system name) 

3. This patch can be installed manually using ONLPAT, the _ on-line 
patching program: 
RUN SONLPAT 
Command File Name? <cr> (RETURN for manual installation) 
File to patch? [0,1]BASIC.RTS (BASIC-PLUS run-time system name) 
File found in account [0,1] 
This feature patch is contained in the file PA0401.004 as part of 
the UPDATE package. To transfer this file to the UPDATES account, 
select the package name UPDATE during the system installation or 
update procedure. 

4. The patch is as follows: 


Base address? ..XTN. 


Offset address? 0 


Base Offset Old New? 
2227??? #000000 020000 ? 0 
222??? QO0002 ??77??? ? *C (up-arrow/C to exit; CTRL/C 


for INIT) 


RSTS/E V9.0 Maintenance Notebook, June 1985 


RSTS/E V9.0 Seq 4.1.4 F 
BASIC-PLUS 

BASIC-PLUS Patches Te Of 2 
5. If the above patch was installed using ONLPAT, it will take effect 


the next time the run-time system is reloaded. If the run-time 


system has been INSTALLED, execute the following commands: 
$ UNLOAD/RUNTIME SYSTEM BASIC  (BASIC-PLUS run-time system name) 
NOTE: The UNLOAD command will not remove the run-time system, but 


Simply instructs the monitor to reload it the next time a job 
requests it. 
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IMMEDIATE MODE FROM .BAS FILE - BASIC-PLUS FEATURE PATCH 


Normally, BASIC-PLUS does not allow immediate-mode commands to appear 
in the file accessed by the "OLD" command. This may be desirable in 
environments where this feature was used in previous versions of 
BASIC-PLUS. To allow BASIC-PLUS to accept immediate mode commands in 
files, apply the patch in this article. 


PROCEDURE: 


1. This is a feature patch to the BASIC-PLUS run-time system. It may 
be installed in any BASIC-PLUS run-time system. 


2. The patch described in Step 4 can be installed using the PATCH 
option of INIT.SYS: 


Option: PATCH 
File to patch? BASIC.RTS (BASIC-PLUS run-time system name) 


3. This patch can be installed manually using ONLPAT, the on-line 
patching program: 


RUN SONLPAT 

Command File Name? <cr> (RETURN for manual installation) 
File to patch? [0,1]BASIC.RTS (BASIC-PLUS run-time system name) 
File found in account [0,1] 


This feature patch is contained in the file PA0401.005 as part of 
the UPDATE package. To transfer this file to the UPDATES account, 
select the package name UPDATE during the system installation or 
update procedure. 


4, The patch is as follows: 


Base address? ..IBAS 
Offset address? 0 


Base Offset Old New? > 
22222? OOO000O0 001401 ? 401 . 
227??? #000002 104767 ? *C (up-arrow/C to exit; CTRL/C 


for INIT) 
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5. If the above patch was installed using ONLPAT, it will take effect 


the next time the run-time system is reloaded. If the run-time 
system has been INSTALLED, execute the following commands: 


$ UNLOAD/RUNTIME SYSTEM BASIC (BASIC-PLUS run-time system name) 


NOTE: The UNLOAD command will not remove the run-time system, but 
Simply instructs the monitor to reload it the next time a job 


requests it. 
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NO PPN'S IN CATALOG COMMAND - BASIC-PLUS FEATURE PATCH 


Normally, BASIC-PLUS allows any user to list the contents of another 
user's directory with the CATALOG [P,PN] command. The patch in this 
article prevents BASIC-PLUS from accepting a project, programmer 
number in the CATALOG command. Thus, only the user's own directory 
may be listed. 


PROCEDURE: 


1. This is a feature patch to the BASIC-PLUS run-time system. It may 
be installed in any BASIC-PLUS run-time system. 


2. The patch described in Step 4 can be installed using the PATCH 
option of INIT.SYS: 


Option: PATCH 
File to patch? BASIC.RTS (BASIC-PLUS run-time system name) 


3. This patch can be installed manually using ONLPAT, the on-line 
patching program: 


RUN SONLPAT 

Command File Name? <cr> (RETURN for manual installation) 
File to patch? [0,1]BASIC.RTS (BASIC-PLUS run-time system name) 
File found in account [0,1] 


This feature patch is contained in the file PA0401.006 as part of 
the UPDATE package. To transfer this file to the UPDATES account, 
select the package name UPDATE during the system installation or 
update procedure. 


4, The patch is as follows: 


Base address? ..CAT. 
Offset address? 0 


Base Offset Old New? 
222??? OQOOO0000 000401 ? 5064 
2???2??? +OO0002 000006 ? *C (up-arrow/C to exit; CTRL/C 


for INIT) 
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5. If the above patch was installed using ONLPAT, it will take effect 


the next time the run-time system is reloaded. If the run-time 
system has been INSTALLED, execute the following commands: 


Ss UNLOAD/RUNTIME_ SYSTEM BASIC (BASIC-PLUS run-time system name) 
NOTE: The UNLOAD command will not remove the run-time system, but 


simply instructs the monitor to reload it the next time a job 
requests it. 
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DISABLING THE CCL SYS CALL - BASIC-PLUS FEATURE PATCH 


Normally, BASIC-PLUS allows any user to execute any valid CCL command 
on the system with SYS call 14. However, some installations may 
choose to disable this feature to discourage users from writing 
programs that will simulate the features of a standard run-time 
system. The patch in this article prevents BASIC-PLUS from executing 
SYS call 14. 


Note 


This patch will disable the execution of the system wide 
LOGIN.COM file when logging in, if the LOGIN program has 
been compiled with BASIC-PLUS (.BAC file type). 


PROCEDURE: 


1. This is a feature patch to the BASIC-PLUS run-time system. It may 
be installed in any BASIC-PLUS run-time system. 


2. The patch described in Step 4 can be installed using the PATCH 
option of init.sys: 


Option: PATCH 
File to patch? BASIC.RTS (BASIC-PLUS run-time system name) 


3. This patch can be installed manually using ONLPAT, the on-line 
patching program: 


RUN SONLPAT 

Command File Name? <cr> (RETURN for manual installation) 
File to patch? [0,1]BASIC.RTS (BASIC-PLUS run-time system name) 
File found in account [0,1] 


This feature patch is contained in the file PA0401.007 as part of 
the UPDATE package. To transfer this file to the UPDATES account, 
select the package name UPDATE during the system installation or 
update procedure. 
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4, The patch is as follows: 


Base address? ..CCL. 
Offset address? 0 


Base Offset Old New? 
222222? QOOOOO0O ???7??? =? UUOBAD 
22??2?2??? OOO002 7777??? ? *C (up-arrow/C to exit; CTRL/C 


for INIT) 


If the above patch was installed using ONLPAT, it will take effect 
the next time the run-time system is reloaded. If the run-time 
system has heen INSTALLED, execute the following commands: 


$ UNLOAD/RUNTIME SYSTEM BASIC (BASIC-PLUS run-time system name) 


NOTE: The UNLOAD command will not remove the run-time system, but 
simply instructs the monitor to reload it the next time a job 
requests it. 
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CLEAR I/O BUFFERS USED BY OPEN STATEMENTS 
- MANDATORY BASIC-PLUS PATCH 


PROBLEM: 


BASIC-PLUS does not clear I/O buffers used by OPEN statements. This 
affects security, as it allows users to examine portions of memory 
allocated to buffers created by the OPEN command. 


SOLUTION: 


This problem is corrected by a patch contained in the command file 
BASIC.CMD and is automatically applied whenever you install or update 
BASIC-PLUS. 


Note 


If you update the BASIC-PLUS runtime system while it is 
installed, you must unload it before the correction will 
take effect. To unload the BASIC-PLUS runtime system, 
issue the command: 


$ UNLOAD/RUNTIME SYSTEM BASIC 
The UNLOAD command does not remove the run-time system; 


it simply instructs the monitor to reload it the next 
time a job requests it. 
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FORCE "ILLEGAL STATEMENT" ERROR WHEN USING OBSOLETE SEND/RECEIVE 
- BASIC-PLUS FEATURE PATCH 


PROBLEM: 


Send/Receive SYS call 18 (SYS(CHRS$(6%)+CHR$(18%)+...) in BASIC-PLUS is 
obsolete and should not be used. New applications should use SYS call 
22 for all send/receive functions. 


SOLUTION: 


The patching procedure detailed in Step 4 will cause BASIC-PLUS to 
generate an "?ITllegal Statement" error whenever the obsolete 
Send/Receive SYS call (SYS(CHRS(6%)+CHRS(18%)+....) is used. This 
patch will help to identify programs which use this obsolete SYS call 
so they may be changed to the new format Send/Receive SYS call (Refer 
to RSTS/E Programming Manual for information). 


Note 


Some programs in the OPSER (Operator Services and 
Spooling) package still use SYS call 18 for send/receive 
functions. You should not apply this feeature patch if 
you are still using the OPSER package. The Print/Batch 
Services package does not use SYS call 18. 


PROCEDURE: 


1. This is a feature patch to the BASIC-PLUS run-time system. It may 
be installed in any BASIC-PLUS run-time system. 


2. The patch described in Step 4 can be installed using the PATCH 
option of INIT.SYS: 


Option: PATCH 
File to patch? BASIC.RTS (BASIC-PLUS run-time system name) 


3. This patch can be installed manually using ONLPAT, the on-line 
patching program: 


RUN SONLPAT 

Command File Name? <cr> (RETURN for manual installation) 
File to patch? [0,1]BASIC.RTS (BASIC-PLUS run-time system name) 
File found in account [0,1] 
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This feature patch is contained in the file PA0401.009 as part of 
the UPDATE package. To transfer this file to the UPDATES account, 
select the package name UPDATE during the system installation or 
update procedure. 


The patch is as follows: 


Base address? ..S18. 
Offset address? 0 


Base Offset Old New? 
2222??? 000000 111302 ? 104771 
2??7?27?? 000002 010246 ? *C (up-arrow/C to exit; CTRL/C 


for INIT) 


If the above patch was installed using ONLPAT, it will take effect 
the next time THE run-time system is reloaded. If the run-time 
system has been INSTALLED, execute THE following commands: 


S$ UNLOAD/RUNTIME SYSTEM BASIC (BASIC-PLUS run-time system name) 
NOTE: The UNLOAD command will not remove the run-time system, but 


Simply instructs the monitor to reload it the next time a job 
requests it. 
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THE BASIC-PLUS DEBUG FACILITY 


A feature of BASIC-PLUS, the DEBUG facility, is available with RSTS/E 
as an unsupported feature, and may be changed or removed in future 
versions of BASIC-PLUS. 


The DEBUG commands extend the present BASIC-PLUS immediate-mode 
debugging commands by allowing you to trace the flow of your program 
and to set breakpoints. These commands provide a subset of the 
functions provided by the BASIC-PLUS-2 debugging facility, and are 
only available as immediate-mode commands. They cannot be used within 
BASIC-PLUS programs. The commands are used in one of two ways: 


- Issuing them between the OLD and RUN of a program and, thereafter, 
whenever a breakpoint is hit. 


- By including STOP statements within the program, and then issuing 
the DEBUG commands’ when the first STOP statement is encountered 
and, thereafter, whenever another STOP statement or breakpoint is 
Are. 


Any DEBUG commands are disabled when: 
- A "RUN <program-name>" command is successfully executed 


A NEW, OLD, or EXIT command is executed 
Any valid CCL command is executed 


The keywords used with the DEBUG facility have been implemented with 
the second character of each keyword changed to a question mark ("?")., 
The patch described in article Seq 4.10.3 F may be used to change the 
question marks to the characters required to make the keyword names 
match the names of their respective functions (for example, "T?ACE" is 
changed to "TRACE"). Note that, if this patch is applied, any program 
with a variable or function name that represents a variant of TRACE, 
UNTRACE, BREAK, or UNBREAK (such as TRACE%, FNBREAKS, etc.) will not 
compile until the variable name is changed. 


For the purposes of this discussion, assume that the patch described 
above has been installed. If you include the DEBUG features, but 
choose not to install the patch, replace all occurrences of the 
keywords below as follows: 


With Without 
Patch Patch 
TRACE T? ACE 


UNTRACE U?TRACE 
“BREAK B?EAK 
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UNBREAK U?BREAK 


TRACE/UNTRACE 

The TRACE command causes BASIC-PLUS to print the message "at line nnn" 
(where "nnn" represents a line number) each time that a line number is 
encountered or the current line number changes. 


The UNTRACE command disables any previous invocation of the TRACE 
command. 


BREAK /UNBREAK 
The BREAK command allows you to specify that execution should stop any 
time that a specified line number is encountered. Up to 10 such 
breakpoints can be set. The BREAK command is of the form: 

BREAK [ Nl, N2, N3 ..., N10 ] 
where "Nn" represents a line number between 1 and 32767. 
When a breakpoint is encountered, BASIC-PLUS prints the message "Break 
at line nnn" and returns to "Ready" as though a STOP statement had 
been executed. At this point you can examine or change the values of 
variables, execute the DUMP command (if enabled, see article 
Seq 4.10.2 N), or execute any other legal command. Type "CONT" 


(continue) to resume execution. 


If the BREAK command is issued without a line number argument, 
BASIC-PLUS will BREAK each time that a new line is encountered. 


The UNBREAK command is used to disable breakpoints, and is of the form 
UNBREAK [ Nl, N2, N3, ..-, N10 ] 


If no line numbers are specified, all breakpoints are disabled. 
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UNDERSTANDING LINE NUMBERS IN THE DEBUG FACILITY 


(This section discusses the actual implementation of the DEBUG 
facility in the BASIC-PLUS run-time system, and should help to explain 
certain anomalies that you may encounter.) 


The DEBUG code is entered whenever an internal construct called a 
"statement header" is encountered. Statement headers are generated 
for the following BASIC-PLUS elements: 


Line numbers DIMENSION statements DATA statements 
FOR statements. NEXT statements 
DEF statements FNEND statements 


When a statement header is encountered, BASIC-PLUS first checks to see 
if the BREAK or TRACE feature has been requested. If not, program 
execution continues. 


If BREAK or TRACE has’ been requested, BASIC-PLUS now compares the 
current line number with the previously encountered line number. ia 
they are the same, program execution continues. 


If a different line number has’ been encountered, BASIC-PLUS then 
checks to see if the statement header represents a function definition 
("DEF") statement. If so, program execution continues. 


Because of the internal structure of BASIC-PLUS, it is not possible to 
BREAK at a function definition. As you can see from the algorithm 
used, any attempt to BREAK at a function definition is rejected while 
the program is being executed, rather than when the BREAK command is 
specified. 


If the BREAK feature has been requested, BASIC-PLUS compares the 
current line number with the list of breakpoints that have been 
requested. If the current line number is included in the breakpoint 
list, BASIC-PLUS prints "Break at line nnn," and returns to _ keyboard 
monitor ("Ready") state. 


If the TRACE feature has been requested, BASIC-PLUS prints "at line 
nnn" and proceeds with execution of the program. 
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SUPPORT POLICY FOR THE BASIC-~PLUS DEBUG FEATURE 


DIGITAL makes no commitment, expressed or implied, to support the 
BASIC-PLUS run-time system, or any BASIC-PLUS System programs (CUSPs) 
used with that run-time system, if the DEBUG feature is enabled in the 
BASIC-PLUS run-time system. 


If you experience problems with the DEBUG feature, please submit an 
FYI-type (priority 5) Software Performance Report (SPR). While making 
no commitment to fix problems reported with the DEBUG facility, 
DIGITAL would like to know about any problems that you encounter. 


ENABLING THE DEBUG FACILITY 


The DEBUG facility requires approximately 160 (decimal) additional 
words in the BASIC-PLUS run-time system. In most cases, this means 
that one or more of the other optional features (String Arithmetic, 
Print Using, etc.) must be omitted to prevent the BASIC-PLUS run-time 
system from exceeding 16K words in size. 


To include the DEBUG facility in your BASIC-PLUS run-time system, 
append "/D" to the name you select at the "BASIC-PLUS RTS name ?" 
query. For example: 


BASIC-PLUS RTS name ? <BASIC> BASIC/D 
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THE BASIC-PLUS DUMP FACILITY 


A feature of BASIC-PLUS, the DUMP facility, is available with RSTS/E 
as an unsupported feature, and may be changed or removed in future 
versions of BASIC-PLUS. 


The keyword D?MP has been implemented to write a post-mortem dump _ to 
the specified file on a random-access device if the patch described in 
article Seq 4.10.4 F is installed. To change the keyword to DUMP, 
also install the patch described in article Seq 4.10.6 F. Note that, 
if this patch is installed, any program with a variable or function 
named DUMP, DUMP%, DUMP$, FNDUMP(), etc. will not compile until the 
name of the variable is changed. 


For the purposes of this discussion, assume that the patch described 
above has been installed. If you enable the DUMP facility, but choose 
not to install this patch, replace all occurrences of "DUMP" with 
"D?MP" in the discussion below. 


The DUMP command provides an extension to the present BASIC-PLUS 
immediate mode debugging commands by allowing you to take a 
"snap-shot" dump of your current job. After DUMPing your program, you 
can use the BPDA (BASIC-PLUS Dump Analyzer) program to display the 
contents of all variables used by the program. In addition, you can 
continue executing your program after issuing the DUMP command; this 
allows you to inspect the state of the program at several stages of 
execution. 


The DUMP command is only available as an immediate-mode command (i.e., 
it cannot be used in a BASIC-PLUS program), and has the syntax: 


DUMP <file-specification> 


If no device name is specified, the public disk structure ("SY:") is 
used. If no filename is specified, the current program name is'- used. 
If no file type is specified, ".PMD" is used. 


THE BASIC-PLUS DUMP ANALYSIS PROGRAM 


After the DUMP command has been issued, you can use the BPDA program 
to print the contents of each variable that is used in the program, as 
well as the contents of the buffer of any open files. 7 


The BPDA program asks for an input file name. The default file type 
is ".PMD". There is no default for the file name. Wildcards are 
illegal. 
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When BPDA asks for the output file name, responding with <cr> will 
direct the output to your terminal. If no filename is specified, the 
input filename is used with the default file type ".PDA". 


You may also respond to the "Input file?" query with a command of the 
form: . 


<outfile> = <infile> 


The DUMP facility has not been implemented as a standard feature 
because it could be used to obtain confidential information, such as 
student grades or payroll information, in applications where a user 
could type CTRL/C and examine the contents of buffers and variables. 
If the feature is enabled, however, there are two mechanisms available 
to protect against this kind of situation: 


~ Non-privileged users are normally prevented from using the DUMP 
command on programs that are running from compiled files. This 
restriction may be removed if desired (see article Seq 4.10.5 F). 


- Whether or not non-privileged users are allowed to use the DUMP 
command on programs that are executed from compiled files, they 
still may not use the DUMP command on a program that uses 
temporary privileges, since the BASIC-PLUS run-time system clears 
the program from memory before a non-privileged user returns to 
keyboard monitor state. 


Some installations may find it desirable to generate two versions of 
the BASIC-PLUS run-time system, one for development and one for 
production. This would prevent the potential problems described 
above, while providing the DUMP feature for development work. 


SUPPORT POLICY FOR THE BASIC-PLUS DUMP FACILITY 


DIGITAL makes no commitment, expressed or implied, to support the 
BASIC-PLUS run-time system, or any BASIC-PLUS System programs (CUSPs) 
used with that run-time system, if the DUMP facility is enabled. 


If you experience problems with the DUMP feature, please submit an 
FYI-type (priority 5) Software Performance Report (SPR). While making 
no commitment to fix problems reported with the DUMP facility, DIGITAL 
would like to know about any problems that you encounter. 
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CHANGING THE BASIC-PLUS DEBUG KEYWORDS - BASIC-PLUS FEATURE PATCH 


PROBLEM: 


If support for the DEBUG facility has been included in the BASIC-PLUS 
run-time system, the keywords BREAK, TRACE, UNBREAK, and UNTRACE are 
initially enabled with the second character of the keyword changed to 
a question mark ("?"), for example, B?EAK, T?ACE, U?BREAK, and 
U?TRACE. 


SOLUTION: 


The following patching procedure will replace the question marks with 
the correct characters, thus changing the keywords to BREAK, TRACE, 
UNBREAK, and UNTRACE. 

NOTE 


If this patch is installed, any program with a variable 
or function name of one of these keywords, such as 
BREAK% or FNTRACES, will fail to compile until the 
variable name has been changed. 


PROCEDURE: 


l. This is a feature patch to the BASIC-PLUS run-time system. It may 
be installed in any BASIC-PLUS run-time system. 


2. The patch described in Step 4 can be installed using the .PATCH 
option of INIT.SYS: 


Option: PATCH 
File to patch? BASIC.RTS (BASIC-PLUS run-time system name) 


3. This patch can be installed manually using ONLPAT, the on-line 
patching program: 


RUN SONLPAT 

Command File Name? <cr> (RETURN for manual installation) 
File to patch? [0,1]BASIC.RTS  (BASIC-PLUS run-time system name) 
File found in account [0,1] 


This feature patch is contained in the file PAQ410.003 as part of 
the UPDATE package. To transfer this file to the UPDATES account, 
select the package name UPDATE during the system installation or 
update procedure. 
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4. The patch is as follows: 


Base address? 
Offset address? 


Base Offset 
2227??? 000000 
22222? OO0001 


Offset address? 
Base address? 
Offset address? 


Base Offset 
777777 «©G00000 
22222? «®2QdOd00D01 


Offset address? 


Base address? .. 


Offset address? 


Base Offset 
2???2??? #+Qd0000 
2222??? «©OO00001 


Offset address? 


Base address? .. 


Offset address? 


Base Offset 
22??2??2?? 000000 
222??? OO0001 


. BEA. 


0 
Old 


077 
oot 


New? 
? 'R 
mays 


New? 
? 'R 
2 OZ 


New? 
? 'N 
27, 


New? 
? 'N 
e OE 


(CTRL/Z 
(CTRL/Z 


(CTRL/Z 
(CTRL/Z 


(CTRL/Z 
(CTRL/Z 


for 
for 


for 
for 


for 
for 


(up-arrow/C 
for INIT) 


new 
new 


new 
new 


new 
new 


Seq 4.10.3 F 
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offset) 
base) 


offset) 
base) 


offset) 
base) 


to exit; CTRL/C 


5. If the above patch was installed using ONLPAT, 


the next time 


the run-time system is reloaded. 


it will take effect 
If the run-time 


system has been INSTALLED, execute the following commands: 


$ UNLOAD/RUNTIME SYSTEM BASIC 


NOTE: 
simply 
requests it. 


instructs 


the 


monitor 


(BASIC-PLUS run-time system name) 


The UNLOAD command will not remove the run-time system, but 
to reload it the next time a job 
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ENABLING THE BASIC-PLUS DUMP FEATURE - BASIC-PLUS FEATURE PATCH 


PROBLEM: 


The (unsupported) BASIC-PLUS "DUMP" feature is initially disabled. 
Some installations may choose to enable this feature, even though it 
is unsupported. (See article Seq 4.10.2 N for a complete description 
of the DUMP feature. See article Seq 4.10.6 N to change the keyword 
from "D?MP" to "DUMP", ) 


SOLUTION: 


The following patching procedure will enable the DUMP feature. 


PROCEDURE: 


1. This is a feature patch to the BASIC-PLUS run-time system. It may 
be installed in any BASIC-PLUS run-time system. 


2. The patch described in Step 4 can be installed using the PATCH 
option of INIT.SYS: 


Option: PATCH 
File to patch? BASIC.RTS (BASIC-PLUS run-time system name) 


3. This patch can be installed manually using ONLPAT, the on-line 
patching program: 


RUN SONLPAT 

Command File Name? <cr> (RETURN for manual installation) 
File to patch? [0,1]BASIC.RTS (BASIC-PLUS run-time system name) 
File found in account [0,1] , 


This feature patch is contained in the file PA0410.004 as part of 
the UPDATE package. To transfer this file to the UPDATES account, 
select the package name UPDATE during the system installation or 
update procedure. 
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4. The patch is as follows: 


Base address? ..PMD. 
Offset address? 0 


Base Offset Old New? 
2222??? #QOOOO00O0 104755 ? BNE+t2 
2????? QOO0002 ?7777?? ? *C (up-arrow/C to exit; CTRL/C 


for INIT) 


If this patch was installed using ONLPAT, it will take effect the 
next time THE run-time system is reloaded. If the run-time system 


hac haan TINCTMATIRN avarita THER Fallawinnd cammandce 
& y Ne WH ELLALELLA SL ENA BS O 


440s OF Nee We 2S am oth & ahd Lande 9 we Rw Ww UK Ww & 24d ae I eA YO 


$ UNLOAD/RUNTIME SYSTEM BASIC (BASIC-PLUS run-time system name) 


NOTE: The UNLOAD command will not remove the run-time system, but 


Simply instructs the monitor to reload it the next time a job 


requests it. 
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ENABLING DUMP FROM COMPILED FILES FOR NON-PRIVILEGED USERS 
- BASIC-PLUS FEATURE PATCH 


PROBLEM: 


Normally, if the DUMP feature is enabled (see article Seq 4.10.2 N), 
BASIC-PLUS will not allow some users to DUMP programs that are 
executing from compiled files, even though they may DUMP programs that 
are executing from source files. This protection prevents users from 
DUMPing programs which may contain confidential information in their 
variable strings or file buffers. In order to use the DUMP command, 
the user must have WACNT, WWRITE, SYSIO and RDMEM privileges. 


Some installations, however, may want to allow all users to DUMP all 
BASIC-PLUS programs to which they have RUN access, regardless of 
whether the program is compiled. 


SOLUTION: 


The following patching procedure will cause BASIC-PLUS to allow all 
users to DUMP programs that they are executing. (Note that a program 
whose protection code includes the 128. bit for temporary privileges 
is always cleared from a non-privileged user's job space before 
returning the keyboard monitor ("Ready") state. Hence, a 
non-privileged user can never DUMP such a program. ) 


PROCEDURE: 


1. This is a feature patch to the BASIC-PLUS run-time system. It may 
be installed in any BASIC-PLUS run-time system. 


2. The patch described in Step 4 can be installed using the PATCH 
option of INIT.SYS: 


Option: PATCH 
File to patch? BASIC.RTS (BASIC-PLUS run-time system name) 


3. This patch can be installed manually using ONLPAT, the on-line 
patching program: 


RUN SONLPAT 

Command File Name? <cr> (RETURN for manual installation) 
File to patch? [0,1]BASIC.RTS (BASIC-PLUS run-time system name) 
File found in account [0,1] 
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This feature patch is contained in the file PA0410.005 as part of 
the UPDATE package. To transfer this file to the UPDATES account, 
select the package name UPDATE during the system installation or 
update procedure. 


4. The patch is as follows: 


Base address? ..NPD. 
Offset address? 0 


Base Offset Old New? 

2222??? 000000 004767 =? NOP 

2222??? 000002 77777? ? NOP 

2?2????? #000004 005046 ? *C (up-arrow/C to exit; CTRL/C 


for INIT) 


6. If the above patch was installed using ONLPAT, it will take effect 
the next time THE run-time system is reloaded. If the run-time 
system has been INSTALLED, execute THE following commands: 


S$ UNLOAD/RUNTIME SYSTEM BASIC (BASIC-PLUS run-time system name) 
NOTE: The UNLOAD command will not remove the run-time system, but 


simply instructs the monitor to reload it the next time a job 
requests it. 
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CHANGING THE BASIC-PLUS D?MP KEYWORD - BASIC-PLUS FEATURE PATCH 


PROBLEM: 


The DUMP command, which is disabled unless the patch described in 
article Seq 4.10.4 F is installed, has been implemented with the 
keyword "D?MP." Some installations may desire to change this keyword 
to "DUMP." 


SOLUTION: 


The following patching procedure will change the keyword "D?MP" to 
"DUMP." If this patch is installed, please note that any program which 
uses a variable or function name such as DUMP% or FNDUMPS, will not 
compile until the variable name is changed. 


PROCEDURE: 


1. This is a feature patch to the BASIC-PLUS run-time system. It may 
be installed in any BASIC-PLUS run-time system. 


2. The patch described in Step 4 can be installed using the PATCH 
option of INIT.SYS: | 


Option: PATCH 
File to patch? BASIC.RTS (BASIC-PLUS run-time system name) 


3. This patch can be installed manually using ONLPAT, the on-line 
patching program: 


RUN SONLPAT 

Command File Name? <cr> (RETURN for manual installation) 
File to patch? [0,1]BASIC.RTS (BASIC-PLUS run-time system name) 
File found in account [0,1] 


This feature patch is contained in the file PA0410.006 as part of 
the UPDATE package. To transfer this file to the UPDATES account, 
select the package name UPDATE during the system installation or 
update procedure. 
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4, The patch is as follows: 


Base address? ..DMP. 
Offset address? 0 


Base Offset Old New? 
222??? #QOdD00D OFT 2s-hy 
P2227??? “000001 eee RAE (up-arrow/C to exit; CTRL/C 


for INIT) 


If this patch was installed using ONLPAT, it will take effect the 
next time THE run-time system is reloaded. If the run-time system 


hae Ra anr TATOMaT TaN mee em eee kh PITT Le NA Ne ee ete aie, elt Abana ens 
tido Vell LINOLALLUGL, CACCULEeE tL 


Pathe ian pero een ae P- Pa 
Ne LOLLOw LY COMUNGIIASs 


$s UNLOAD/RUNTIME SYSTEM BASIC (BASIC-PLUS run-time system name) 


NOTE: The UNLOAD command will not remove the run-time system, but 
simply instructs the monitor to reload it the next time a job 
requests it. 
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BUFFER LIMIT CHECKING - MANDATORY 2780 DEVICE DRIVER PATCH 


PROBLEM: 


The RSTS/E extended buffering scheme in effect since V0O6B obsoletes 
the buffer limit checking code in the 2780 device driver. This buffer 
limit checking code was removed from the DUI11/DUP11 version of the 
driver, but was left in the DPl1l version. Certain valid buffer 
addresses will cause the DP1l version to fail. 


SOLUTION: 
This problem is corrected by a patch contained in the file RJ2780.CMD 
in the SYSGENS account. This patch is automatically applied whenever 
you generate a RSTS/E monitor that includes support for the RJ2780 
package. 

Note 


This patch will fail when applied to a monitor that is 
not configured to include DPll devices. 


For further details on how to generate a RSTS/E monitor, see the 


RSTS/E System Installation and Update Guide. 
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DISCONNECT COMMAND HANDLING - MANDATORY 2780 DEVICE DRIVER PATCH 


PROBLEM: 


If the 2780 device driver receives a disconnect command (DLE EOT), it 
mistakenly releases its buffers and line table. A subsequent close 
will cause modification of critical monitor memory. A system crash 
may occur thereafter. 


SOLUTION: 


This problem is corrected by a patch contained in the file RJ2780.CMD 
in the SYSGENS$ account. This patch is automatically applied whenever 
you generate a RSTS/E monitor that includes support for the RJ2780 
package. 


For further details on how to generate a RSTS/E monitor, see the 


RSTS/E System Installation and Update Guide. 
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DP11 TRANSMIT HANG CONDITION - MANDATORY 2780 DEVICE DRIVER PATCH 


PROBLEM: 


Under certain load conditions, when the 2780 package issues the error 
‘Send Error - Transmit Hang - Redial Required’, critical locations in 
the monitor can be modified. This will cause a subsequent system 
crash. 


SOLUTION: 
This problem is corrected by a patch contained in the file RJ2780.CMD 
in the SYSGENS$ account. This patch is automatically applied whenever 
you generate a RSTS/E monitor that includes support for the RJ2780 
package. : 

Note 


This patch will fail when applied to a monitor that is 
not configured to include DP1ll devices. 


For further details on how to generate a RSTS/E monitor, see the 


RSTS/E System Installation and Update Guide. 


RSTS/E V9.0 Maintenance Notebook, June 1985 


RSTS/E V9.0 | Seq 5.1.4 M 
RSTS/E 2780 Device Driver 

2780 Device Driver Patches 1 of 1 
DU11/DUP11 TRANSMIT HANG CONDITION - MANDATORY 2780 DEVICE DRIVER 
PATCH 

PROBLEM: 


Under certain load conditions, when the 2780 package issues the error 
"Send Error - Transmit Hang - Redial Required', critical locations in 
the monitor can be modified. This will cause a subsequent system 
crash. 


SOLUTION: 


This problem is corrected by a patch contained in the file RJ2780.CMD 
in the SYSGENS$S account. This patch is automatically applied whenever 
you generate a RSTS/E monitor that includes support for the RJ2780 
package. 


Note 


This patch will fail when applied to a monitor that is 
not configured to include DU11/DUP11 devices. 


For further details on how to generate a RSTS/E monitor, see the 


RSTS/E System Installation and Update Guide. 


RSTS/E V9.0 Maintenance Notebook, June 1985 


RSTS/E V9.0 Seq 5.1.5 M 
RSTS/E 2780 Device Driver 
2780 Device Driver Patches 1 of 1 


LOSS OR DUPLICATION OF DATA - MANDATORY 2780 DEVICE DRIVER PATCH 


PROBLEM: 


Occasionally the loss or duplication of data occurs. There is no 
indication from the 2780 package that any trouble had occurred. 


SOLUTION: 


This problem is corrected by a patch contained in the file RJ2780.CMD 
in the SYSGENS account. This patch is automatically applied whenever 
you generate a RSTS/E monitor that includes support for the RJ2780 
package. 


For further details on how to generate a RSTS/E monitor, see _ the 


RSTS/E System Installation and Update Guide. 
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DOUBLE CLOSE ALTERS MONITOR - MANDATORY 2780 DEVICE DRIVER PATCH 


PROBLEM: 


The 2780 Device Driver does not protect itself against closing the RJ: 
device twice in all cases. A double close can alter monitor memory 
and cause a system crash. 


SOLUTION: 


This problem is corrected by a patch contained in the file RJ2780.CMD 
in the SYSGEN$ account. This patch is automatically applied whenever 
you generate a RSTS/E monitor that includes support for the RJ2780 
package. 


For further details on how to generate a RSTS/E monitor, see the 
RSTS/E System Installation and Update Guide. 
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GET/PUT INTERLOCK PROBLEM - MANDATORY 2780 DEVICE DRIVER PATCH 


PROBLEM: 


Due to timing considerations on systems with zero turn-around delay, 
it 1S possible for a bid from a remote unit to be processed before the 
completion of the routine for End Of Transmission. This causes’ the 
driver to receive the bid when it "thinks" it is in transmit mode and 
the GET/PUT INTERLOCK error is triggered. 


SOLUTION: 


This problem is corrected by a patch contained in the file RJ2780.CMD 
in the SYSGENS$ account. This patch is automatically applied whenever 
you generate a RSTS/E monitor that includes support for the RJ2780 
package. 


For further details on how to generate a RSTS/E monitor, see the 


RSTS/E System Installation and Update Guide. 


RSTS/E V9.0 Maintenance Notebook, June 1985 


RSTS/E V9.0 Seq 5.1.8 M 
RSTS/E 2780 Device Driver 
2780 Device Driver Patches 1 of 1 


2780 HANDLER FAILURE PROBLEM - MANDATORY 2780 DEVICE DRIVER PATCH 


PROBLEM: 


When the RSTS/E system is under heavy load, it is possible for. the 
notification of the receipt of a bid to be passed back with a receive 
buffer address of zero. When the driver attempts to requeue_ the 
buffer, it 1s considered a fatal error. 


SOLUTION: 


This problem is corrected by a patch contained in the file RJ2780.CMD 
in the SYSGENS account. This patch is automatically applied whenever 
you generate a RSTS/E monitor that includes support for the RJ2780 
package. 


For further details on how to generate a RSTS/E monitor, see the 


RSTS/E System Installation and Update Guide. 
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LOCAL BINARY TRANSMIT PROBLEM - MANDATORY 2780 DEVICE DRIVER PATCH 


PROBLEM: 


If the default transmit command is 2780 or GEN, it should be possible 
to send, as part of a multiple file transfer, a file or files in 
binary mode. This is done by using the "/B" switch to override the 
transmit command for those files which should be sent untranslated. 
Currently, the mode of the first file controls the mode for _ the 
complete transfer. 


SOLUTION: 


This problem is corrected by a patch contained in the file RJ2780.CMD 
in the SYSGENS$ account. This patch is automatically applied whenever 
you generate a RSTS/E monitor that includes support for the RJ2780 
package. 


For further details on how to generate a RSTS/E monitor, see the 


RSTS/E System Installation and Update Guide. 
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INSTALLING AND TROUBLESHOOTING 2780'S 


Installing a communication package involves a minimum of two vendors 
and more likely three or four. The most time-consuming aspect of 
installation can be pinpointing a problem. When installing A_ to 
communicate with B, the problem may be in one of seven areas: 


A's software (either code or SYSGEN parameters) 
- A's hardware 

- A's modem 

~ Phone line 

- B's modem 

- B's hardware 

- B's software 


Sometimes a given symptom can have several possible causes. Then it 
is necessary to go through a step-by-step elimination procedure. 


Here are some ideas and suggestions which may be helpful when 
difficulties arise in installation of 2780 packages. 


1. What is a 2780 and what is its protocol? 


For those who are unfamiliar with what a 2780 emulator is emulating, 
here is a short description of what it is and what its protocol is 
like. 


The 2780 is an unintelligent, hard-wired terminal which can 
communicate to an IBM host or to another 2780. It reads cards and 
transmits them over a synchronous link to another computer. It 
receives data back and prints it. The model 2 2780 can also receive 
back data for a card punch. 


The 2780 sends 80 character card image records, blocked into a maximum 
of a 400 character block. For reception, it prints or punchs a file 
according to a peripheral selection code (basically, an ESC 4 sends a 
file to the punch). It is able to accept horizontal tabs and handles 
them according to the spacing of a special HT record which is sent at 
the beginning of the file. The block size is again a maximum of 400 
characters. 
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A synchronous protocol is used to enable the data to be sent back | and 
forth. The protocol determines who speaks, when, and whether or not 
the other end heard them correctly. When there is_ synchronous 
communication, the two modems sample the line at a preset speed (2000 
times a second or 4800, etc.), and the data is sent in blocks with one 
character directly following another. Every message, therefore, 
whether a single control character or a 400 character block is 
preceded by four SYNC characters and followed by a PAD. The SYNC 
characters are used to allow the hardware to tell when valid data is 
coming (as opposed to noise on the line), and the PAD is used to make 
sure that the final significant character is fully received. Every 
data record . sent has a CRC (cyclic redundancy check) computed on its 
characters, and following each record and block (IUS, ETB, and ETX) is 
a two-character checksum which is. used to make sure the data was 
received correctly. 


The major control characters used in the 2780 protocol are: 


ENQ (enquiry): (1) Used to request permission to send 
data (bid); 
(2) Used to request resending of a 
missed response. | 


ACKO (acknowledge): (1) Used to give permission to_ send 
data; 
(2) Used to accept every other data 
block. 

ACK1 (acknowledge): Used to accept every other data block. 

NAK (negative acknowledge): Used to reject a data block. 

STX (start of text): Used to indicate the beginning of a 
data block. 

ETB (end of block): Used to indicate the end of a data 
block. 

ETX (end of text): Normally used to indicate the end of 


the final block of the job. 
IUS (intermediate record end): Used to indicate the end of a_ record. 
EOT (end of transmission): Used to indicate completed 


transmission and give up control of 
line. 
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A sample job might be sent as 


STX 


STX 


STX 


STX 


STX 


ENQ 


STX 


EOT 


DATA1 


DATA2 


DATA3 


DATA3 


DATA4 


ETB 


ETB 


ETB 


ETB 


ETX 


ETX 


ACKO 


ACK1 


ACKO 


NAK 


ACK1 


ACK] 


ACKO 


ENQ 


Seq 5.2.1N 
3 of 8 


follows: 


;request permission to send 
;permission given 

sblock of data 
sacknowledge correct reception 


sanother block 


;rejection of data 


sresending of data block 


;.3 second silence request for response 
;response shows did not see block, 
Since an ACKO is the expected 
response for DATA4 


sblock re-sent 


;transmission complete 


;other side requests permission to 
send data 


RSTS/E V9.0 Maintenance Notebook, June 1985 


RSTS/E V9.0 Seq 5.2.1 N 
RSTS/E 2780 Device Driver 
2780 Device Driver Notes 4 of 8 


2. What to check before installation of the software. 
There are some questions to be asked before 2780 installation. 


What operating system will you be communicating with? If it is not 
another PDP-1l, is it one of the usual IBM systems? If it is a 
different system (for example, a Univac 1108 with a Comterm front end 
or an RPG program running on a System 3, etc.) has a demo test been 
done with the system, and what problems, if any, were encountered? 


What kind of modems are being used? If they are not identical, are 
they compatible. If they are the same type, are the options the same 
on both? If it is a local connection are modem eliminators being 
used, or are null modems being used? Null modems require a clocking 
option on the computer hardware to provide transmit clocking. Are the 
modems for a speed higher than is warranted by the software? RSX11M, 
RSX11D, and RSTS/E are not warranted to work over 4800 baud. 


Make sure that the modem has been grounded on the same ground as the 
hardware. The communications interface and many modems can _ be 
affected by being plugged into a device which is grounded differently. 


Is the DP11l, DU11, or DUP11 the furthest forward device on the _ bus 
(except the system disk) which operates at hardware level 5? If there 
is a DH11 or DZ1l1 on the system, it will probably be necessary to 
raise the hardware level of the communications interface to 6. This is 
because the DH1l often is programmed to remain at interrupt level 
until the silo is emptied (the DZ1ll has no silo and must interrupt per 
character). 


Have the diagnostics been run for the communications interface and the 
KGl1? The DP, DU, or DUP should be checked out with the turn-around 
plug at the end of the modem cable or with the modem in maintenance 
mode. 


Two manuals are shipped with the 2780 software. They are the 2780 RCS 
Users Guide* and the 2780 RCS Installation Notes (DEC-11-CCDNA-A-D). 
Relevant chapters should be read in advance of installation. There 
will be some overlap between this article and the manuals, but in many 
ways they should complement each other. 


* DEC-11-ORJEA-B-D is for RSTS/E 2780 only. 
DEC-11-CRCSA-A-D, DN1, DN2, DN3, and DN4 are for the other 2780's. 
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3. Initial attempt to run 


One of the more frustrating circumstances is to bring up the package, 
issue a transmit command, and have it do absolutely nothing. Silence, 
however, can be just as informative aS a mesSSage. 


This section will itemize the things that can go wrong in the sequence 
in which they would be encountered. It 1S specified when systems 
react in different ways. The systems involved are RT11, RSX11M, 
RSX11D, and RSTS/E. 


a. Run the program for the first time and 
(1) there is a trap to 4 in RT1ll and RSTS/E 
(2) there is an odd address trap abort in RSX11M or D 


Probably the device address of the DU11l or DUP11 iS incorrect. They 
are floating device address devices. Check that the device was 
installed at the correct address (for example, if the DU1l1 is the only 
floating device on the system it will be at 760040, if the DUP11 is 
the only floating device it will be at 760050) and also that the 
system was told the same _ address. RSTS/E calculates the address 
during boot, RT1l1, RSX11M and D have it specified during taskbuild. 
The KGll may also be missing. This is the hardware CRC calculator. 
If it 1S missing the software cannot run. 


b. Run the program and get ready to make the connect to the other 
system. Dial the phone, receive the beep from the other end, and 
push (or pull) the data button and 

(1) the data light does not come on 

(2) the DSR (or MR) indicator does not light. 


Usually a dial-out modem will not give DSR (data set ready) until DTR 
(data terminal ready) has been presented by the communications 
interface 


(1) check that the light is not just burned out 

(2) check that you have put the system on-line (all systems 
but RSTS/E) | | 

(3) check that the DTR bit is on in the status word 

(4) check that a valid but incorrect device address was not 
used (RT11, RSX11M and D) 

(5) check that the hardware diagnostics were run, including 
the one uSing the modem cable. 

(6) check that the cable is securely plugged into the modem 


With a leased line, the modem often has DSR strapped on. In that 
case, this type of error may not be discovered until later in the 
procedure (see c. and d.). There are now some dial-out modems (for 
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example, some MILGO modems) which have DSR strapped on also. They 


will react the same as the leased line modems. 


Cc. 


The program has been run and the connection established; a 
transmit transfer command is issued and a modem (or data _ set) 
not ready message is given. 

(1) the data set is not ready (for example, DSR is not up) 

(2) a valid, but incorrect, device address has been used. 


This is at the same stage as c. The first transmit command has 
been issued, but nothing happens. There are several possible 
causes. 


(1) Incorrect interrupt vector (RSX11M and D). Since in these 
systems interrupt vector 1s specified at build time, check 
that it corresponds to the actual hardware vector. 


(2) No response to the bid (RT11, RSX11M and D). These systems 
do an infinite retry on the bid if they get no- response. 
(RSTS/E does a timeout). Unfortunately, this cause is 
really a symptom with multiple causes of its own. Some 
possibilities are: 


(a) the remote end software is not up (usually leased 
line) or the connection was not made (a dial-out modem 
with DSR strapped on). 

(b) the modems have different speeds (for example, 2000 
baud talking to 2400). 

(c) the modem is not sending out the signal (this can 
usually be checked by finding out whether the other 
side has seen the bid). 

(d) the other end is responding, but the turn-around time 
is too fast (usually on a two-wire dial-out system 
where there are echo suppressers on the line). 

(e) the other end is responding but the modem either does 
not see it (receive strength too low) or the modem 
does not pass it back (bad receive leads on the 
modem), or our hardware does not see it (bad receive 
chip or modem cable - this should be caught by 
diagnostics or actual zero turn-around delay (see 
Fi) 


To determine whether or not the bid is actually being sent 
out, check the receive end to see if it has gone into receive 
mode. If it is in receive mode, but the transmitting side is 
still in control mode, the bid is being seen but the response 
is not (or the response is not considered valid). 
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e. A transmit command is given and the program aborts. In RT1l1 


if the wrong interrupt vector has been specified, the program 
is aborted and the monitor reprompts. In RSX11M if the 2780 
is running ina partition that can be 'shuffled' the program 
may have been moved. This will have completely unpredictable 
effects, since the interrupt will jump to where the correct 
code used to be. 


When attempting to transmit there are frequent transmit abort 
errors. Each system has its own version of the error message, 
but they all indicate that either eight attempts to send a 
data block were NAKed, or eight attempts to get a valid 
response were ignored. 


On RSTS/E VO6B and later releases, a status request will show 
whether the data is being NAKed or timed-out. In the other 
packages an error request will show the number of NAKs. If the 
transmit iS aborting, but there are few or no NAKs the problem 
is timeouts. 


If the first block is not being accepted, the KGll may not be 
working correctly. If it is improperly seated the program may 
be sending out a CRC of zeros. This should be easily caught 
by diagnostics. 


On a multi-user system the package should not be run at a 
higher speed than is warranted. 


On a multi-user system with a DH11 or DZ1l1, the communications 
interface should be at hardware bus request level 6. 


Other possibilities are: modems with different turn-around 
delays, bad modems, incompatible modems, and noisy phone 
lines. 


If there is an actual zero turn-around delay (not just a modem 
with no delay, but a system with a front-end which is’ capable 
of responding without any processing delays) it is possible to 
have the response return while our hardware is_ sending 
trailing pads. Either a minimum delay time should be 
installed or the number of trailing pads should be decreased. 


Transmit works fine, but files cannot be received. 


Most of the suggestions for f. should be checked. Two of the 
most likely ones are running at too high a speed for the 
system, or having the communication interface at level 5 ona 
system with high DH11 or DZ1l1 load. 
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If no data from the other side is accepted at all it is quite 
possible that the other system is SYSGEN'd to support either a 
3780 or a HASP Workstation instead of a 2780. Our data will be 
acceptable to their side, since the 2780 is, in effect, a 
subset of the other two. In both cases, the data block can be 
too long (they will both send up to 512 characters and the 
2780 can only accept 400) and the CRC calculations are done on 
the complete block instead of on each record. The usual 
indication is that we consistently NAK the very first block 
that they attempt to send to us. 


re tha SAA oad SYSGEN'd aca DIAN but 


ig §«6©oUner SiGe id osisual a5 GQ 2ruou, ndin 

long a record (over 132 data characters plus a two character 
escape sequence) most of our packages will now accept the 
record and truncate it (as long as there were no. other 
problems with the data). The user will be informed as to the 
number of truncated records at the end of the reception. 


The package has been transmitting and receiving without 
difficulty. It is in the middle of transmitting and all 
activity stops. The package is in transmit mode, but nothing 
is going out. 


This is usually caused by losing DSR on a modem which will not 
give CTS (clear to send) to a RTS (request to send) if DSR has 
been lost (for example, BELL 208B modems). Check the modem, 
and if this is correct, try to push the talk button and _ then 
the data button to try to re-establish the connection. If 
that does not work you will have to redial. RSTS/E VO6B (and 
later releases) will timeout in 30 seconds and terminate 
transmit. The other packages will not terminate until 
operator intervention has taken place. 


Installation is complete when the program has been brought up, a 
connection made, and files transmitted and received. 


RSTS/E V9.0 Maintenance Notebook, June 1985 


RSTS/E V9.0 Seq 12.1.1N 
Error Control Package (ERRORS) 
Package Notes 1.°Of <2 


UNDERSTANDING "PA MEMORY SYSTEM" ERROR LOGS 


The following information is logged when a memory error causes a 


trap or 
fact that 


CACHECTL 


ADDR LSB 


ADDR MSB 


MEM ERR 


an instruction abort. These logs can be recognized by the 
"MEM ERR" 1S not zero. 


This is the data RSTS/E sets into the Cache Control Register 
(777746). It is meaningless for systems without cache 
memory. 


These words contain the address of the word in memory which 
failed. 


On the PDP-11/70, they are the contents of the Low Error 
Address Register (777740) and High Error Address’ Register 
(777742). Bits <15:14> of ADDR MSB indicate the cycle type 
of the failure. On other processors, these words are 
assembled from the other logged information. 


On processors with cache, this is the contents of the Memory 
System Error register (777744). On other processors, this 
word always contains 100000 (CPU Abort, no cache error). If 
the same cache group fails twice in the same minute, that 
cache group will be disabled. 


The remaining registers are not logged on the 11/70, which does not 
have accessible memory CSRs. In any case, they are not meaningful 
unless the error occurred in main memory. 


CSR 


(CSR) 


K Range 


# Fail 


This is the address of the CSR which indicated an error. 


This is the contents of that CSR. A second entry is also 
printed for an MS11M or MS11L with the extended address 
function selected. 


This tells how finely the CSR contents can resolve the 
location of the error. For all current memory controllers 
(MF11-LP, MF11-UP, MF11-WP, MF11S-K, MM11-DP, MM11-YP, and 
MS11-JP), this value is 1, indicating that the CSR locates 
the error to within 1K _ words. For older semiconductor 
memory controllers (MS11-AP, MS11-BP, and MS11-CP) that do 
not provide the address of the error in the CSR, this value 
is the number of 1K-word blocks (up to 31.) controlled by 
the CSR. 


When it discovers a CSR announcing an error, RSTS/E looks 
through all memory in the range of the error (see above) to 
find which words actually have errors. Thus, for a 
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controller which resolves the error location to within 1- 
words, RSTS/E checks 1024. words (or 512. if the memory is 
interleaved). This word tells how many words in the range 
had an error indication. 


Base Adr To get the physical address of the start of the _ range 
mentioned above, add two zero digits (six bits) to this 
value. 


Fail #n The next words in the error log tell which words in the 
given range actually have errors. The addresses are given 
as byte offsets from the base given above. Up to five such 
offsets may be logged. 


Once a second, except on 11/70's, RSTS/E checks all memory CSRs_ for 
errors that do not cause traps or aborts. The logs for these errors 
can be recognized by the fact that "MEM ERR" is zero. These errors 
include uncorrectable errors detected on NPR cycles, and correctable 
(single-bit) ECC errors. Uncorrectable errors are logged whenever 
they are detected, but only one correctable error will be logged for 
each CSR, for each time RSTS/E is started. When a correctable error 
is logged, only the CSR address and CSR contents will be meaningful. 
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NOTES ON THE USE OF THE SERIAL LA180 (LA180S) TERMINAL 


The first part of this article describes the behavior of the Serial 
LA180 terminal (called the LA180S) when its power is turned off, 
either at system start-up time or at some later time during 
timesharing, and makes recommendations to prevent loss of data. 


If any terminal (including an LA180S) is powered off when the system 
is booted, the device appears to the system to be operational. If a 
user tries to print a file on the terminal, the system will send 
characters to the device at the usual speed and assume that they are 
being printed properly. Obviously, since the device iS powered off, 
the characters are not being printed, but the device cannot return any 
indication of that fact to the system. The entire file will be sent 
as if it were printing. 


If a spooler is started on such a KB: line, any files queued to that 
spooler will be sent, just as if the device were printing properly. 
The queue will gradually empty, and any files queued with /DELETE will 
be deleted. 


Since there is no method by which the software can differentiate 
between a terminal which is powered off and one which is printing 
properly, it is highly recommended that the person starting up a 
RSTS/E system check to ensure that all terminal devices which are 
ordinarily spooled are powered on and properly online before system 
Start-up is performed. 


A second class of problems involves the behavior of the LA180S when it 
is powered off or powered on after it has been ALLOCATEd or OPENed. 


During its power down and power up sequence, the LA180S terminal may 
send spurious characters to the host processor. The ASCII code of 
these characters appears to be random, but they occasionally take on 
the value of control characters (for example, CTRL/C). Since the 
program printing on the terminal may not expect input of any kind from 
the terminal, these spurious characters may result in unexpected 
errors: a CTRL/C may cause the program to exit; a  CTRL/O will cause 
all further output to be discarded without printing; and so on. 
There is no way for the software to protect against all possible 
spurious inputs. RSTS/E is able to protect against all spurious input 
except CTRL/S (XON) and CTRL/Q (XOFF) via the MODE 32% option on _ the 
OPEN statement. However, spurious XON/XOFF characters can still cause 
loss of synchronization between the host system and the terminal. The 
only way to prevent this problem is to ensure that the LA180S is never 
powered off or powered on while it is ALLOCATEd or OPENed. 
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A final problem concerns loss of data when the LA180S is powered off. 
The LA180S contains an internal buffer which is used to _ hold 
characters which have been received from the host processor but which 
have not yet been printed. When the LA180S goes OFFLINE (either 
because the ONLINE/OFFLINE switch is placed in the OFFLINE position, 
or because some exception condition, such as a paper jam, has been 
detected) this buffer may still contain some unprinted data. If the 
terminal is placed back ONLINE, printing will resume with no loss of 
data. If, however, the terminal is turned off, the buffer is cleared 
and any data in the buffer is lost. The only protection against this 
loss is to ensure that the LA180S is not powered off while it is 


nrintina 
DPIneinc. 


In summary, DIGITAL recommends that any LA180S terminal to be used 
under RSTS/E timesharing be powered on before system start-up and that 
it remain on whenever it is in use. If the terminal is powered off, 
loss of data and unexpected errors may result. 


Another kind of problem has been encountered when spooling to an 
LA180S. This problem concerns the manner in which the terminal device 
handles printed lines that are longer than the width of the terminal. 


When a line is printed on the LA180S, the device prints characters 
until it gets to the physical right margin. At that point, the logic 
of the terminal inhibits further printing until a carriage return 
character moves the print head back from the margin. When a CR is 
encountered in such ae situation, the LA180S also generates a 
line-feed, causing spacing to a new line. Since most print lines are 
terminated by a CR/LF sequence, however, the second LF will, again, 
cause spacing to a new line, leaving one line blank. Thus, printing a 
line which is longer than the width of the LA180S (for example, longer 
than 132 characters) will cause a blank line on the printed output. 
-p When performing normal print operations under RSTS/E, the user will 
not ordinarily encounter this problem. The RSTS/E Terminal Service 
ordinarily keeps track of the characters printed on the terminal and 
explicitly issues a CR/LF sequence to the terminal when the print head 
reaches the right margin (as defined by the /WIDTH qualifier in a SET 
TERMINAL command). Thus, lines printed to that terminal which are 
longer than the width of the terminal result in printing of all 
characters, but on multiple lines. The only programs which will have 
trouble are those which need to keep track of vertical position on the 
page (for example, the line printer spooler) and, therefore, invoke 
the special MODE (Mode 4%) to inhibit the automatic CR/LF by terminal 
service. Files printed by such programs will have blank lines after 
each line which was longer than the terminal width. There iS no 
practical software remedy for this problem. 
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USING TWO OR MORE PRINTERS TO SERVE A QUEUE 


It 1S possible to have two or more printers serve a single print 
queue, For example, you can have two printers serve the LPO: queue, 
which is the default queue. Ordinary print jobs (those queued to 
LPO:) would be printed on either printer. 


This feature is most useful when you have two or more similar printers 
in the same vicinity. It is not generally useful to have a fast and a 
slow printer serve the same queue, nor to have two printers in 
different locations serve the same queue. 


A different form can be mounted on each printer. If this is done, the 
spooling package will automatically select the printer that has the 
correct form for a particular job. Or, if the correct form is not 
mounted on any available printer, the spooling package will hold the 
job. : 


Start up each spooler by running the SPOOL program, as discussed in 
the RSTS/E System Manager's Guide. Specify the same queue name for 
each -- for example, specify LPO: if the spoolers are to serve the 
LPO: queue. But you must use the /NAME:rcvrid switch to ensure that 
each spooler is given a different receiver ID. Otherwise, the SPOOL 
program will print the message "?Duplicate receiver ID." 


In the following example, the devices LPO: and LPl: both serve the 
queue named LPO:. 


RUN OPSERS:SPOOL 
#LPO: /NAME:LPO/PHYSICAL: LPO: 
Detaching ... 


RUN OPSERS : SPOOL 
#LPO:/NAME:LP1/PHYSICAL:LP1: 
Detaching ... 


To avoid confusion, a queue should not have the same name as a printer 
that serves another queue. For example, if queue LPO: is served by 
printers LPO: and LPl:, then you would not want to name another queue 
LPl:. 
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FILE SPECIFICATIONS IN DCL 


The rules about file specifications in DCL are slightly more 
restrictive than elsewhere in RSTS/E. 


The special PPN character "!" does not work in DCL. The exclamation 
point is used as the comment delimiter. 


The special PPN characters "@", "$", "&", and "#" are accepted in the 
current version, but their use is not supported. They are reserved 
DCL characters, and may have other meanings in the future. 


The special PPN character "$" is legal and supported in DCL. It will 
continue to designate the system library [1,2]. 


The traditional RSTS/E file specification switches /MODE, /SIZE, and 
/RONLY cannot be used in DCL. Many of the same features are available 
through DCL, but you must use DCL notation. Protection codes in angle 
brackets ("<nn>") cannot be used in DCL. The DCL syntax for 
protection codes is "/PROTECTION:nn". 


Parentheses ("()") cannot be used to delimit the project-programmer 
number of a file in DCL. Brackets ("{]") must be used instead. 
Parentheses are reserved DCL characters. 


The single-character wildcard "?" works in DCL, but it is unsupported. 
It may have a different meaning in the future. 
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SETTING UP THE DCL LINK COMMAND 


This article explains how to set up your system so that the DCL LINK 
command can be used. If you intend that the LINK command will be 
used, you should read this article before you install any layered 
languages. Other aspects of setting up DCL are described in the 


RSTS/E System Installation and Update Guide and the RSTS/E System 
Manager's Guide. 


The DCL LINK command provides a simple way of linking programs. It 
lets you link programs in two RTll-based languages (FORTRAN-IV_ and 
MACRO-11) and five RSX-ll-based languages (BASIC-PLUS-2, COBOL-81, 
DIBOL, FORTRAN-77, and MACRO/RSX). With several of these languages, 
the LINK command also lets you specify an overlay structure using a 
Simple dialogue. 


The requirements for setting up the LINK command depend on _ what 
languages you want to be able to link with, and whether you want to be 
able to link with FMS. The following paragraphs explain how to set 
LINK up for each language. 


The default language assumed by the LINK command is BASIC-PLUS-2. You 
may wantto change this default if your installation does not have 
BASIC-PLUS-2, or if you prefer that a different language be the 
default. To do this you could assign the GLOBAL symbol LINK :== 
LINK/language in the system-wide LOGIN.COM file. 


Disabling Languages 


You should disable linking with a particular language if your 
installation does not have all of the files or other requirements 
for that language. The following table shows what file to delete 


for each language to be disabled. These files are installed 
automatically. 
Language to Disable File to Delete 
All RSX-based languages [1,2]PRELIN.TSK 
BASIC-PLUS-2 LB:BP2.LNK 
COBOL-81 LB:C81.LNK 
DIBOL LB:DIBOL.LNK and LB:DMS.LNK 
FORTRAN-IV (none) 
FORTRAN-77 LB: F77.LNK 
MACRO/RT11 (none) 
MACRO/RSX LB:RSX11.LNK 


If a user tries to link with a language you have disabled in this 
manner, DCL will display the message "?Command not installed." 
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Requirements for RT1ll-based Languages 


-MACRO-11 
Location Required File When Installed 
sv:[1,2] LINK.SAV RSTS/E System Generation 
Sy:[1,2] SYSLIB.OBJ RSTS/E System Generation 
LINK/RT11 is automatically disabled if LINK.SAV is not present. If 


LINK.SAV is not present and a user types LINK/RT11, DCL will display 


o_o 


the mMmESSage "?Command not installed.’ 


FORTRAN-IV V2.5 


Location Required File When Installed 

SY:[1,2] LINK. SAV. RSTS/E System Generation 

SY¥:(1,2] SYSLIB.OBJ RSTS/E System Generation 

SY:[1,2] FORLIB.OBJ FORTRAN-IV Installation 
Note: 


ia 


When you install FORTRAN-IV you have the options of either 
including the FORTRAN library routines in SYSLIB.OBJ or 
putting them separately, in FORLIB.OBJ. For LINK/FOR to work 
properly, select FORLIB.OBJ. 


LINK/FOR is automatically disabled if LINK.SAV is not 
present. If LINK.SAV is not present and a_e user types 
LINK/RT11, the system will display the message "?Command not 
installed." 
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Requirements for RSX-based Languages 


All of the RSX-based languages have certain linking requirements 
in common: 


Location Required File When Installed 

SY:(1,2] PRELIN. TSK RSTS/E Installation 
Sy:([1,2] TKB.TSK RSTS/E RSX Emulator Build 
LB: RMSRES.TSK RSTS/E RMS Installation 
LB: RMSRES.STB RSTS/E RMS Installation 
RMSS: RMSRES.LIB RSTS/E RMS Installation 
LB: RMSLIB.OLB RSTS/E RMS Installation 
LB: SYSLIB.OLB RSTS/E RSX Emulator Build 
LB: RMSRLX.ODL RSTS/E RMS Installation 
l. When you generate your system specify RSX emulation in the 


monitor and resident library support. Answer YES to. the 
questions "Resident libraries ?" and "RSX directives ?" 


Install the RSX Emulator Package. 

Establish a library account with the system-wide logical 
name LB:. (This is done automatically during the RSX 
installation.) 


Install the RMS. package. Select the RMSRES resident 
library. 


ADD the RMSRES resident library. 


Ensure PRELIN.TSK (pre-link) program has a protection code 
of 232. 
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Forms Management System 


You can use Digital's Forms Management System (FMS) with 
languages. 


the 


RSX-based 


Location 


:[0,1] (usually) 


There 


are 


Required File 


FDVRES. TSK 
FDVRES.STB 
FDVRES.LIB 
FDVRES.OLB 
HLLDFN.OBJ 
FDVDRS . OBJ 


1. ADD the FDVRES resident library. 


2. 


You must 


have 


the 


appropriate 


interface file in account LB:. 


BASIC-—PLUS- 2; 
FORTRAN-77; 


HLLDBL.OBJ 
and HLLCOB.OBJ 


for 


These are: 


for 
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any of 


certain requirements for 
setting up the LINK command to link FMS into the program: 


When Installed 


Installation 
Installation 
Installation 
Installation 
Installation 
Installation 


DIBOL; 


installed during FMS Installation. 


BASIC-PLUS-2 V2.3 


Location 


:[0,1] (usually) 


Required File 


BP2.LNK 
BASICS.TSK 
BASICS.STB 


~BASICS.LIB 


BASRMS. OLB 
BP2COM.OLB 
BP2IC7.ODL 


ADD the BASICS resident library. 


If 


high-level 

HLLBP2.OBJ for 
HLLFOR. OBJ 
COBOL-81. 


language 


for 


They are 


When Installed 


RSTS/E Installation 


BAS IC-PLUS-2 
BASIC-PLUS-2 
BASIC-PLUS~-2 
BAS IC-PLUS-2 
BAS IC-PLUS-2 
BASIC-PLUS-2 


Installation 
Installation 
Installation 
Installation 
Installation 
Installation 


you gave a name other than BP2COM to the BASIC-PLUS-2 
object library, then edit the file LB:BP2.LNK, and 


change 


LB:BP2COM.OLB to the appropriate file specification. 
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COBOL-81 V2.3 


Location Required File When Installed 

SY:(1,2] C810DL.TSK COBOL-81 Installation 

SY¥:{1,2] ATPK.TSK RSTS/E Standard CUSP 
Build 

SY. 2. PIP.SAV RSTS/E System Generation 


Additionally, if you select CIS (Commercial Instruction Set) 
when you install COBOL-81: 


LB: C81CIS.TSK COBOL-81 Installation 
LB: C81CIS.STB COBOL-81 Installation 
SY¥:[0,1] (usually) C81CIS.LIB COBOL-81 Installation 


If you select NONCIS when you install COBOL-81: 


LB: C81LIB.TSK COBOL-81 Installation 

LB: C81L1IB.STB COBOL-81 Installation 

SY¥:[0,1] (usually) C81LIB.LIB COBOL-81 Installation 
Note: 


1. ATPK'sS protection code must include 128. In other words, 
it must be ae privileged program. The standard CUSP 
installation procedure sets ATPK's protection code to 232, 
which is satisfactory. 


2. ADD the COBOL resident library, C81CIS or C8l1LIB. 


If [1,2]PIP.SAV or [1,2]C81ODL.TSK is not present, the LINK 
command will fail with "?Can't find file or account." If 
[1,2]ATPK is not present, the LINK command will fail with 
"?Unexpected error in PRELIN ... ?Can't find file or account." 
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DIBOL V5.1A, using RMS 


Location 


ee ce re ee ee ee ee 


SY:[0,1] (usually) 


1. When you install DIBOL V5.1A select the 


(rather than DMS). 


DIBOL V5.1A, using DMS 


Location 


1. When you install DIBOL V5.1A select the 


Required File 
DIBOL.LNK 
DIBOLR.TSK 
DIBOLR.STB 
DIBOLR.LIB 
RMSUSL.OLB 
RMSOSL.OLB 


Required File 
DMS . LNK 
DIBOLD.TSK 
DIBOLD.STB 
DIBOLD.LIB 
DMSUSL.OLB 
DMSOSL.OLB 


(rather than RMS). 
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When Installed 


RSTS/E Installation 


DIBOL 
DIBOL 
DIBOL 
DIBOL 
DIBOL 


Installation 
Installation 
Installation 
Installation 
Installation 


RMS I/O package 


When Installed 


RSTS/E Installation 


DIBOL 
DIBOL 
DIBOL 
DIBOL 
DIBOL 


Installation 
Installation 
Installation 
Installation 
Installation 


DMS I/O package 


RSTS/E V9.0 


RSTS/E V9.0 
DCL 
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FORTRAN-77 V5.0-14 


Location Required File When Installed 

LB: F77.LNK RSTS/E Installation 

LB: F4POTS.OLB FORTRAN-77 Installation 

LB: RMS11M.ODL FORTRAN-77 Installation 
Note: - 

1. When you install the FORTRAN-77 V5.0 compiler select the 


RMS I/O package (rather than FCS). 


. When you install FORTRAN-77 you have the option of either 


including the FORTRAN library routines in SYSLIB.OLB or 
putting them separately in F4POTS.OLB. For LINK/F77 to 
work properly, select F4POTS.OLB. 


Edit the file LB:RMS11M.ODL. Change all occurrences of 
"EBS Ls. |" to Dt OF = Bien ne : 


RSTS/E V9.0 Maintenance Notebook, June 1985 


RSTS/E V9.0 Seq 21.1.1N 
RSX Emulator and Utilities Package 
Package Notes l1 of l 


USING RTSODT FOR DEBUGGING RUN-TIME SYSTEMS 


A version of ODT is provided on the RSTS/E V9.0 distribution kit as an 
unsupported feature which can be linked with user-written run-time 
systems. 
To use RTSODT with run-time systems that are assembled and task-built 
under the RSX run-time system you may specify "RTSODT" in the ODL 
file. For example: 
ODTBLD.ODL 

*k* RSXODT.RTS OVERLAY DESCRIPTION *** 


RSXODT VERSION V7.2 


=e se Wo We Ne We 


- NAME RSXODT 
- ROOT RSXODT-LB: SYSLIB/DL-RSXEMU-RSXPMD-RSXRUN-RSXPLA-RSXKBM-ODT 


; 
; RSXRTS MUST BE THE FIRST MODULE LINKED IN ANY RSX BASED RTS 
; RSXODT MUST BE THE LAST MODULE LINKED IN IF YOU WANT ODT 


RSXEMU: .FCTR LB: SYSLIB/LB: RSXRTS: RSXIO:RSXAST:RSXSST:RSXDIR 
RSXPMD: .FCTR LB: SYSLIB/LB: RSXPMD 
RSXRUN: .FCTR LB: SYSLIB/LB: RSXRUN 
RSXPLA: .FCTR LB: SYSLIB/LB:RSXPLA 
RSXKBM: .FCTR LB: SYSLIB/LB: RSXKBM: RSXAT : RSXHLP: RSKXMCR 
ODT: «PE CTR LB: SYSLIB/LB: RTSODT 
- END 


Refer to article Seq 22.1.2 N for a description of the use of RTSODT 
with run-time systems that are assembled and linked under the RT11 
run-time system. 


RSTS/E V9.0 Maintenance Notebook, June 1985 


RSTS/E V9.0 
RSX Emulator and Utilities Package 
CRF.TSK 


Seq 21.2.1N 


1 of 2 


USING THE RSX CRF UTILITY 


The RSX utility CRF.TSK is included on the RSTS distribution kit as an 
unsupported product. It is installed in the system library ($) 
account with other components in the RSX package. 


This program will create cross-reference listings from the binary 
cross reference (.CRF) files optionally produced by the RSX task 
builder (TKB) and RSX MACRO assembler (MAC). The cross reference file 
created by MAC lists page and line number references to data items and 


routines, whereas the cross reference file created by TKB lists’ tha 
names of the object modules which reference these items. The 
following are examples of these two types of output: 

MACRO Assembler output: 

CRF CREATED BY MACRO ON 15-JUN-85 AT 06:02 PAGE 1 

SYMBOL CROSS REFERENCE CREF 07.065 
SYMBOL VALUE REFERENCES 

CR = 000015 #4-180 

FF = 000014 #4-180 

HT = 000011 #4-180 

LF = 000012 #4-180 

LSSIST = ****kkx L=i LZ 2-53 4-182 

RSTS = 000001 #4-39 

RS$11M = 000000 #4-38 

SPA = 000040 #4-180 

VT = 000013 #4-180 

V1145 = Eee ene 4-157 

SSSVER = 034066 #3-2 #5-1 

Task Builder output: 

CRF CREATED BY TKB ON 15-JUN-85 AT 06:23 PAGE 1 

GLOBAL CROSS REFERENCE CREF 07.065 


SYMBOL VALUE REFERENCES... 
A.BTTN 000002 # DIRSYM 

A.DFUI 000102 CRFIN # FCSGBL 
A.LULU 000002 # DIRSYM 

A.LUNA 000004 # DIRSYM 

A.LUNU 000006 # DIRSYM 

A.TRBA 000002 # DIRSYM 

BADDIR 000001 # ERR ELE 
BADNAM 000002 # ERR FIP 
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More details on the CRF output can be found in the RSTS/E Programmer's 
Utilities Manual. 


To request that MAC or _ TKB produce a binary cross-reference file, 
specify the /CR switch in the command line to these programs. For MAC 
the switch is included with the listing file specification and for TKB 
it 1s included with the map file specification. The binary file 
created has the same name as the listing or map file and its file type 
is always .CRF. nee 


CRF.TSK is run uSing either the RUN command or the CRF CCL if 
installed. When run using the RUN command, CRF will prompt with 
"CRF>". Typing CTRL/Z to this prompt will cause an exit to your 
default RTS. The command line is a single RSTS/E file specification 
of the file into which the cross reference listing is to be placed. 
The default file type for this file is .LST. If the file specified 
already exists, CRF appends the listing to it; otherwise, a new file’ 
is created. The CRF output is variable length records and, therefore, 
if the file specified for output already exists, it must also be a 
variable length file. The listing file produced by MAC and the map 
file created by TKB are both variable length files making them prime 
candidates. 


CRF also accepts aS input an indirect command file (preceded by "@") 
which can contain a list of file specifications. Each specification 
in the file will be processed as if it was separately entered to the 
"CRF>" prompt. The default file type for the command file is .CMD. 
CRF only allows one level of command indirection. 


CRF requires the binary cross-reference file to have the same name as 
the output file with a file type of ".CRF". CRF always deletes’ the 
binary ".CRF" file when it is done. Therefore, if it is desirable to 
keep the binary file, it must be copied to a non-".CRF" file prior to 
running CRF.TSK. 


RSTS/E V9.0 Maintenance Notebook, June 1985. 


RSTS/E V9.0 Seq 22.1.1N 
RT-11 Emulator and Utilities Package 
Package Notes Lok 


USE OF UNDERSCORE IN RT-11 EMULATOR UTILITIES | 


RSTS/E allows the use of the underscore (_) character before a device 
name in a file specification to indicate that the device name is not 
to undergo logical translation. Utilities provided with the RT-11 
emulator will allow the use of the underscore character; however, due 
to the nature of the emulator, it is still possible for the device 
name to undergo translation before a file is opened. 


In the RT-11 emulator, file specifications given to a utility are 
scanned using the RT-11 CSI (command string interpreter). At this 
time, the device designation may or may not undergo logical 
translation (depending on whether or not the underscore was used). The 
CSI returns RT-11 file description blocks to the utilities. 


When the utility program then requests the emulator to open a file, 
the file open code does an additional logical translation on _ the 
specified device name. This is an unavoidable consequence of allowing 
logical device names to be specified in RT-11 file description blocks. 
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USING RTSODT FOR DEBUGGING RUN-TIME SYSTEMS 


A version of ODT is provided on the RSTS/E distribution kit as an 
unsupported feature which can be linked with user-written run-time 
systems. 


To use RTSODT with run-time systems that are assembled and _ linked 
under the RT1l run-time system, execute the following commands: 


RUN SLBR.TSK<cr> 
LBR>RTSODT. OBJ=LB: SYSLIB/EX: RTSODT<cr> 
LBR>*~Z 


Ready 


RUN SPIP.SAV<cr> 
*RTSODT.OBJ=RTSODT.OBJ/RMS: FB<cr> 
KA? 


Ready 


You may now include RTSODT.OBJ in the list of input files during the 
LINK. For example: 


RUN SLINK<cr> 

*RT1LIOD/Z,RTLIOD/W, RTL1LOD=RT11/X/H: #177776/U: #4000/C<cr> 
*#ERR.STB, #RTSODT<cr> 

*PATCH<cr> 

KATZ, 


Ready 
Refer to article Seq 21.1.1 N for a description of the use of RTSODT 


with run-time systems that are assembled and linked under the RSX 
run-time system. 
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NOTES ON HOOK.SAV 


HOOK.SAV is a program which will write a bootstrap program on RSTS/E 
file-structured disks and magnetic tapes. Though it is intended only 
for use during system installation, it can be used to make any RSTS/E 
file-structured disk or tape bootable. 


Creating a bootable RSTS/E File-structured Disk 


Mount the disk to be HOOKed: 


$ MOUNT xxn:packid/NOSHARE 
Copy INIT.SYS from your system disk to the output device: 


$ COPY SY0:[0,1]JINIT.SYS xxn:[0,1l]JINIT.SYS/CLUSTER SIZE=16 
Then, run HOOK.SAV: 


S RUN SYSGENS : HOOK. SAV<cr> 
<HOOK's header line> 
*xxn:(0,1]INIT.SYS<cr> 
Hook complete 

KAZ 


S 
Creating a bootable RSTS/E DOS-format Magnetic Tape 


Mount a scratch magnetic tape on a tape drive. (Note that HOOK.SAV 
will zero the tape before using it.) Then, run HOOK.SAV: 


S$ RUN SYSGENS :HOOK.SAV<cr> 
<HOOK's header line> 
*xxn:[0,l]JINIT.SYS/D[:n.],SY0:[0,1JINIT.SYS<cr> 


Hook complete 
KAZ 


$ 
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1. Magnetic tape density: Specify "/D:n" after the "output" 
dev:filnam, as follows: 

/D:800. Set 800 BPI, odd parity 

/D Same as /D:800. 

/D:1600. Set 1600 BPI, phase encoded 

/D:1600 Same as /D:1600. 


Note: 
o /D:800 (no dot) is an illegal specification 


o If /D is not specified, the drive's current settings are 
used. 


o HOOK will allocate the tape drive to you, in DOS format, at 
the density that you specify (or do not specify). 


Normally, HOOK finds the bootstraps for disks and magnetic tapes 
in SY0:[0,1]INIT.SYS. If, as may happen on a development machine, 
[0,1]INIT.SYS does not have the most recent version of the 
appropriate bootstrap, you can specify an alternate file in which 
to find the bootstraps. Hence, a full HOOK command line looks 
like: 


<outdev:filename> , <file for mt-only> , <bootstraps> 
The bootstrap file should look like INIT.SYS. 


HOOK writes magnetic tapes with DOS labels. If the tape is 
written at 800 bpi, the name of the first file on the tape will be 
[0,1]MTBOOT.SYS. If the tape is written at 1600 bpi, the name of 
the first file will be [0,1]MSBOOT.SYS. Note that the difference 
ls important; the 800 bpi bootstrap is significantly different 
from the 1600 bpi bootstrap. 


If no filename is specified with the device specification for 
magnetic tape, the default name INIT.SYS is used, with the current 
PPN. In other words, if you are logged in under [123,1] and 
specify 


MTO:/D:800.,[0,1]FOO.FOO 


the files on the tape will be "[0,1]MTBOOT.SYS" and 
"£123,1]INITLSYS". 
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If you have any reason to wonder if a magnetic tape is bootable, 
check the directory, which should have 2 files with legal RSTS/E 
filenames. The first file should be 1 block long (2 blocks on 
SAVE set tapes, which are bootable tapes created by SAVRES). If 
the directory looks unusual, it is not a bootable RSTS/E tape. 


5. The following might be useful information. 
Standard command lines: 


DLO:[{0,1]INIT.SYS 
Load and execute [0,1]INIT.SYS when DLO: is booted. 


MM1:(0,1JINIT.SYS/D:1600,DR0:(0,1JINIT.SYS 
Load and execute MM1:[0,1JINIT.SYS when MMl: is’ booted; 
copy the file to be executed from DRO:[0,1]INIT.SYS; set 
the density to 1600 bpi. 


Non-standard command line: 


DB3:([0,1]INIT.SYS,,[4,4]NEWINI.SYS 
Load and execute [0,1]INIT.SYS when DB3: is booted; get 
the bootstrap from [4,4]NEWINI.SYS. 


6. Possible Errors: 


?Can't open disk NFS 
Someone else iS using the disk to be HOOKed, or you do 
not have WRTNFS and SYSMOD privileges. 


?Can't open [0,1]SYO0:INIT.SYS 
You must have WREAD,WRTNFS, and SYSMOD privileges to 
run HOOK.SAV 


?Directory error 
The output disk is not a valid RSTS/E file-structured 
disk. 


?File high limit too large 
The file to be loaded by the bootstrap program is too 
large. 


?Error reading boot block 
An I/O error occurred while reading the disk to be 
HOOKed; it may be offline. 
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?Error writing boot block ; 
An I/O error occurred while writing the bootstrap 
program; the disk may be write-locked. 


?Error reading INIT.SYS 
An I/O error occurred while ere INIT.SYS. 


?Explicit unit number required 
The device name specified must include an explicit 
unit number. 


?Il11 cmd? 


HOOK.SAV could not interpret the specified command 
line. 


?Illegal density 
The density that you specified cannot be used on this 
tape drive. 


?Illegal overlay number in INIT 
You are uSing an obsolete version of INIT.SYS. 


?INIT.SYS is not a SAV format SIL 
You are uSing an obsolete version of INIT.SYS. 


?INIT.SYS is too fragmented 
Occurs on disk if the INIT.SYS file being hooked is 
sufficiently fragmented across the disk that the boot 
block pointers to INIT do not fit in the boot block. 
Solution: make INIT contiguous or as a minimum uSe a 
clustersize of 16 for INIT. 


?Not a bootable device 
HOOK.SAV cannot write a bootstrap for that device. 


?Null file can't be hooked 
Self explanatory. 


?No BOOT in STB 
You are uSing an obsolete version of INIT.SYS. 


Second input file required for magtape hook 
You must specify a file to be copied to the magnetic 
tape. 


?UFD open failure 
An I/O error occurred. 
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FAILURE TO CLEAR 'JOB ACTIVE' ON ATTACH - MANDATORY RJ2780 PATCH 
NOTE 


This patch appeared in an earlier issue of the RSTS/E 
VO6B-02 Software Dispatch (September, 1977) as a patch 
to the RSTS/E VO6B RJ2780.BAS program. Since the same 
program is used under’ the V9.0 system, this patch is 
being republished for the RSTS/E V9.0 Software Dispatch 
Review. Because of this, the edit level remains at 
"VO6B-03". If you have applied the earlier VO6B patch, 
do not apply this patch again. 


PROBLEM: 


Once RJ2780 has been put into SPOOL mode, an ATTACH should cause _ any 
job being sent by QUEMAN to be REQUEUEd, and all variables in the 
RJ2780 program itself concerning that job to be cleared. Processing 
should then resume, taking input from the terminal to which the 
program is ATTACHed. When SPOOL mode is’ re-entered, the same job 
should be sent by QUEMAN, and processed by the RJ2780 program. 
Instead, the RJ2780 program becomes confused when it receives a new 
SPOOL command, and the NEWJOB sent by QUEMAN causes an error message 
and the job is not processed. 


SOLUTION: 


The following patch causes reset of all variables upon ATTACH. 


PROCEDURE: 


1. For purposes of the discussion, we will assume that the required 
program to be patched is located on the public disk structure. In 
the patching procedure, we will refer to the program by its most 
Simple name format: <program name>.BAS. The person performing the 
patching operation should, if necessary, replace all program 
references with suitable text according to the requirements of the 
installation. 


Also, for purposes of presenting the patching procedure, we assume 
that the patching operation will be performed in a privileged 
account. 
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2. This mandatory patch is contained in the file PA2502.001 as part 
of the UPDATE package. To transfer this file to the UPDATES 
account, select the package name UPDATE during the system 
installation or update procedure. 


3. To apply the patch automatically, perform the following RSTS/E 
system commands: 


RUN SCPATCH<cr> 
<CPATCH's header line> 


File to patch - RJ2780.BAS=RJ2780.BAS<cr> 
#[ logfile=]JUPDATES :PA2502.001l<cr> 


4.,##To apply the patch menue ty. perform the following RSTS/E 
system commands. 


RUN SCPATCH<cr> 
<CPATCH's header line> 


File to patch - RJ2780.BAS=RJ2780.BAS<cr> 


#[ logfile=]<cr> 
*H/6!/V<cr> 


6! EDIT ne 03 
*G/03/1/A/V<cr> 

6! EDIT : O3A 
*H/7!/V<cr> 

7! EDIT DATE : 02-JUN-77 
*G/02-JUN-77/-9C/06-JUL-77/V<cr> 

7! EDIT DATE : 06-JUL-77 
*H/21!/V<cr> 

21! VER/ED EDIT DATE REASON 
*G/REASON/I<cr> 

<lf> 


!<tab>6B-03A<tab><tab>6-JUL-77<tab>FIX ATTACH/DETACH PROBLEM WITH<1l1f> 
!<tab><tab><tab><tab><tab>QUEMAN COMMUNICATION. <esc>*V<cr> 
! QUEMAN COMMUNICATION. 
*H/1010<tab>/V<cr> 
1010 IS="VO06B-03" 
*G/03/I/A/V<cr> 
1010 IS="VO6B-03A" 
*H/1492<tab>/V<cr> 
1492 MS="ATTACH" 
*G/DETACH%S=/V<cr> 
\ DETACHS=((E3% AND 1%)<>03) 
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*QAI<cr> 
<tab>\ INJOB%,ABTJOB%=0%<1f> 
<esc>*V<cr> 

\ DETACH$=((E3% AND 1%)<>03%) 
*EX<cr> 
Patch from KB:[P,PN]CPATCH.CMD complete 
#°Z 
File to patch - %2Z 


Ready 
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5. To re-compile the program and re-enter it into the system library, 


type the following RSTS/E commands. 
OLD RJ2780<cr> 
Ready 
COMPILE $RJ2780<cr> 


Ready 


The person making the changes to the program should now take 
whatever steps are necessary, according to installation 
guidelines, to save the new version of the program. 


The source (.BAS) version of the program should now be removed 
from the public structure. 


ra 
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LOCAL BINARY TRANSMIT FAILURE - MANDATORY RJ2780 PATCH 
NOTE 


RJ2780.BAS as released with RSTS/E VO6B is used on all 
VO6B and later versions of RSTS/E. For this reason, the 
edit level of the program remains at "V0O6B-03". 


PROBLEM: 


If the default transmit command is 2780 or GEN, it should be possible 
to send, as part of a multiple file transfer, a file or files in 
binary mode. This is done by using the "/B" switch to override the 
transmit command for those files which should be sent untranslated. 
Currently, the mode of the first file of a multiple file transfer 
controls the mode for the complete transfer. 


SOLUTION: 
The following patching procedure will correct this problem. 
NOTE 


The mandatory 2780 Device Driver patch described in 
article Seq 5.1.9 M, published in this notebook, must be 
installed along with this patch. 


PROCEDURE: 


1. For purposes of the discussion, we will assume that the required 
program to be patched is located on the public disk structure. In 
the patching procedure, we will refer to the program by its most 
Simple name format: <program name>.BAS. The person performing the 
patching operation should, if necessary, replace all program 
references with suitable text according to the requirements of the 
installation. 


Also, for purposes of presenting the patching procedure, we assume 
that the patching operation will be performed in a privileged 
account. 
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2. The command file for this patch appears in patch kit version "A" 
or later. If you do not have this distribution you can produce a 
command file by specifying a file for peer eee ] in the following 
procedure. 


To apply the patch manually, perform the following RSTS/E system 
commands: 


RUN SCPATCH<cr> 
<CPATCH's header line> 


File to patch - RJ2780.BAS=RJ2780.BAS<cr> 
#[ logfile=]<cr> 
*H/6!/V<cr> 7 | 
6! EDIT : O3A 
*G/03A/1/B/V<cr> | 
6! EDIT : 03AB 
*H/7'1/V<cr> 
7} EDIT DATE : 06-JUL-77 
*G/06-JUL-77/-9C/23-MAR-79/V<cr> 
7! EDIT DATE : 23-MAR-79 
*H/21!/G/REASON/V<cr> 
21! VER/ED EDIT DATE REASON 
*T<cr> 
<lf> 
~ t<tab>6B-03AB<tab><tab>23- -MAR- 79<tab>FIX LOCAL BINARY PROBLEM. <esc>*V<cr> 
! 6B-03AB 23-MAR-79  FIX,LOCAL BINARY PROBLEM. 
*H/1010<tab>/V<cr> 
1010 IS="V06B-03A" 
*G/03A/1I/B/V<cr> 
1010 IS="V06B-03AB" 
*H/4010<tab>/V<cr> 
4010 FIELD #1%, 134% AS B1S 
*1OAV<cr> 


! FIELD THE RJ: BUFFER. 
*I<cr> 
<tab>\ PUTBIN%=NEWBIN3<l1f> 
<esc>*V<cr> 
! FIELD THE RJ: BUFFER. 
*H/4130<tab>/V<cr> 
4130 FS=LEFT(CHRS (27%) +FS,MAXLEN%) IF X.TEST% AND 128% 
*8AV<cr> 
\ RETURN 
*T<cr> 
<tab>\ PUTBIN%=NEWBIN%S<l1f> 
<esc>*V<cr> 


\ RETURN 


RSTS/E V9.0 Maintenance Notebook, June 1985 


RSTS/E V9.0 
RSTS/E 2780 Package V3.0 
RJ2780 


*H/4230<tab>/V<cr> 
4230 E% ,E2%=0% 
*3AV<cr> 

\ PUTBIN%=(R% OR (B1% AND B2%)) AND 13 
*G/PUTBIN/-6C/NEWBIN/V<cr> 

NEWBINS=(R%¥ OR (B1% AND B2%)) AND 13% 

*EX<cr> 
Patch from KB:[P,PN]CPATCH.CMD complete 
#°Z 
File to patch - %Z 


Ready 
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3. To re-compile the program and re-enter it into the system library, 


type the following RSTS/E commands: 
OLD RJ2780<cr> 
Ready 
COMPILE $RJ2780<cr> 


Ready 


4, The person making the changes to the program 
whatever steps are necessary, according 
guidelines, to save the new version of the program. 


5. The source (.BAS) version of the program 
from the public structure. 


should 


should 


to 
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be 


now take 
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